* fns.c (Fputhash): Document return value.
[bpt/emacs.git] / etc / NEWS
CommitLineData
29b7722a 1GNU Emacs NEWS -- history of user-visible changes.
5b87ad55 2
73b0cd50 3Copyright (C) 2010-2011 Free Software Foundation, Inc.
5b87ad55 4See the end of the file for license conditions.
a933dad1 5
893db5bc 6Please send Emacs bug reports to bug-gnu-emacs@gnu.org.
9a21d88b
KS
7If possible, use M-x report-emacs-bug.
8
eb199145 9This file is about changes in Emacs version 24.
9a21d88b 10
eb199145
GM
11See files NEWS.23, NEWS.22, NEWS.21, NEWS.20, NEWS.19, NEWS.18,
12and NEWS.1-17 for changes in older Emacs versions.
9a21d88b
KS
13
14You can narrow news to a specific version by calling `view-emacs-news'
15with a prefix argument or by typing C-u C-h C-n.
3f7194ed 16
adce950d
CY
17
18Temporary note:
19 +++ indicates that the appropriate manual has already been updated.
20 --- means no change in the manuals is called for.
21When you add a new item, please add it without either +++ or ---
22so we will look at it and add it to the manual.
23
24\f
eb199145 25* Installation Changes in Emacs 24.1
09e18d03 26
338648ad
GM
27** Configure links against libselinux if it is found.
28You can disable this by using --without-selinux.
29
30---
31** By default, the installed Info and man pages are compressed.
32You can disable this by configuring --without-compress-info.
33
aded53ff
GM
34---
35** There are new configure options:
36--with-mmdf, --with-mail-unlink, --with-mailhost.
37These provide no new functionality, they just remove the need to edit
38lib-src/Makefile by hand in order to use the associated features.
39
e547b051 40---
30c4d8dc 41** Emacs can be compiled against Gtk+ 3.0 if you pass --with-x-toolkit=gtk3
e547b051
J
42to configure. Note that other libraries used by Emacs, RSVG and GConf,
43also depend on Gtk+. You can disable them with --without-rsvg and
44--without-gconf.
45
d9170db5
DN
46** There is a new configure option --enable-use-lisp-union-type.
47This is only useful for Emacs developers to debug certain types of bugs.
b2957ea8 48This is not a new feature; only the configure flag is new.
d9170db5 49
d064e6a6 50---
f042970d 51** New translation of the Emacs Tutorial in Hebrew is available.
d064e6a6
EZ
52Type `C-u C-h t' to choose it in case your language setup doesn't
53automatically select it.
54
0bfd685e 55\f
eb199145 56* Startup Changes in Emacs 24.1
4a263588 57
198a7a97 58** The --unibyte, --multibyte, --no-multibyte, and --no-unibyte
adbf62ff
GM
59command line arguments, and the EMACS_UNIBYTE environment variable, no
60longer have any effect. (They were declared obsolete in Emacs 23.)
198a7a97 61
66b7b0fe
GM
62** New command line option `--no-site-lisp' removes site-lisp directories
63from load-path. -Q now implies this.
64
71edd0ec
JB
65** On Windows, Emacs now warns when the obsolete _emacs init file is used,
66and also when HOME is set to C:\ by default.
8a05b668 67
0bfd685e 68\f
eb199145 69* Changes in Emacs 24.1
7841339b 70
fd6fa53f
SM
71** The inactive minibuffer has its own major mode `minibuffer-inactive-mode'.
72This is handy for minibuffer-only frames, and is also used for the "mouse-1
73pops up *Messages*" feature, which can now easily be changed.
74
2a847524
CY
75** emacsclient changes
76
77*** New emacsclient argument --parent-id ID can be used to open a
0191e222
CY
78client frame in parent X window ID, via XEmbed. This works like the
79--parent-id argument to Emacs.
80
15a7a774 81+++
d862b746
GM
82*** New emacsclient argument -q/--quiet suppresses some status messages.
83
2a847524
CY
84*** If emacsclient shuts down as a result of Emacs signalling an
85error, its exit status is 1.
86
a2a25d24 87** Completion
e17d9003
SM
88*** shell-mode uses pcomplete rules, with the standard completion UI.
89
a2a25d24
SM
90*** Many packages have been changed to use completion-at-point rather than
91their own completion code.
92
93*** Completion in a non-minibuffer now tries to detect the end of completion
94and pops down the *Completions* buffer accordingly.
95
96*** Completion can cycle, depending on completion-cycle-threshold.
902a6d8d 97
a2a25d24
SM
98*** New completion style `substring'.
99
620c53a6
SM
100*** Completion style can be set per-category `completion-category-overrides'.
101
102*** Completion of buffers now uses substring completion by default.
103
a2a25d24 104*** `completing-read' can be customized using the new variable
f042970d 105`completing-read-function'.
3ec03f7e 106
2372f278
SM
107** auto-mode-case-fold is now enabled by default.
108
d0ce9f8c
MB
109** Internationalization changes
110
f4b6ba46 111+++
d0ce9f8c 112*** Emacs now supports display and editing of bidirectional text.
f4b6ba46
EZ
113
114See the node "Bidirectional Editing" in the Emacs Manual for some
115initial documentation.
116
117To turn this on in any given buffer, set the buffer-local variable
118`bidi-display-reordering' to a non-nil value. The default is nil.
119
120The buffer-local variable `bidi-paragraph-direction', if non-nil,
121forces each paragraph in the buffer to have its base direction
122according to the value of this variable. Possible values are
123`right-to-left' and `left-to-right'. If the value is nil (the
124default), Emacs determines the base direction of each paragraph from
125its text, as specified by the Unicode Bidirectional Algorithm.
126
d20e1419
EZ
127The function `current-bidi-paragraph-direction' returns the actual
128value of paragraph base direction at point.
129
f4b6ba46
EZ
130Reordering of bidirectional text for display in Emacs is a "Full
131bidirectionality" class implementation of the Unicode Bidirectional
132Algorithm.
133
46759717
EZ
134Note that some advanced display features, such as overlay strings and
135`display' text properties, do not yet work correctly when
136bidirectional text is reordered for display.
137
d0ce9f8c
MB
138+++
139*** Enhanced support for characters that have no glyphs in available fonts.
140If a character has no glyphs in any of the available fonts, Emacs by
141default will display it either as a hexadecimal code in a box or as a
142thin 1-pixel space. In addition to these two methods, Emacs can
143display these characters as empty box, as an acronym, or not display
144them at all. To change how these characters are displayed, customize
145the variable `glyphless-char-display-control'.
146
147On character terminals these methods are used for characters that
148cannot be encoded by the `terminal-coding-system'.
149
150*** There are two new input methods for Persian/Farsi: farsi and farsi-translit.
151
303500aa 152** GTK scroll-bars are now placed on the right by default.
52834b6b
CY
153Use `set-scroll-bar-mode' to change this.
154
20fe03ad 155** GTK tool bars can have just text, just images or images and text.
d8004abe 156Customize `tool-bar-style' to choose style. On a Gnome desktop, the default
20fe03ad
JD
157is taken from the desktop settings.
158
8b2dd508
JD
159** GTK tool bars can be placed on the left/right or top/bottom of the frame.
160The frame-parameter tool-bar-position controls this. It takes the values
1c0d77cc 161top, left, right or bottom. The Options => Show/Hide menu has entries
8b2dd508
JD
162for this.
163
8740c12d 164** ImageMagick support.
b2fa3a09
GM
165It is now possible to use the ImageMagick library to load many new
166image formats in Emacs. By default, Emacs links with the ImageMagick
f5b06c35
GM
167libraries if they are present at build time. This needs ImageMagick
1686.2.8 or newer (versions newer than 6.0.7 _may_ work but have not been
169tested). To disable ImageMagick support, use the configure option
fa6996bc 170`--without-imagemagick'.
16a91140 171
8740c12d
GM
172The new function `imagemagick-types' returns a list of image file
173extensions that your installation of ImageMagick supports. The
174function `imagemagick-register-types' enables ImageMagick support for
b2957ea8 175these image types, minus those listed in `imagemagick-types-inhibit'.
16a91140 176
8740c12d 177See the Emacs Lisp Reference Manual for more information.
16a91140 178
3a46642b
J
179** The colors for selected text (the region face) are taken from the GTK
180theme when Emacs is built with GTK.
181
aa1859f5
J
182** Emacs uses GTK tooltips by default if built with GTK. You can turn that
183off by customizing x-gtk-use-system-tooltips.
184
1ecb2d3f 185** Lucid menus and dialogs can display antialiased fonts if Emacs is built
3928f2b6
JD
186with Xft. To change font, use the X resource font, for example:
187Emacs.pane.menubar.font: Courier-12
99852628 188
917794d5 189** On graphical displays, the mode-line no longer ends in dashes.
1dd3c2d9
CY
190Also, the first dash (which does not indicate anything) is just
191displayed as a space.
917794d5 192
5ffb62aa 193** On Nextstep/OSX, the menu bar can be hidden by customizing
f042970d 194ns-auto-hide-menu-bar.
5ffb62aa 195
b7d65a5f
GM
196** Basic SELinux support has been added.
197This requires Emacs to be linked with libselinux at build time.
198
d8004abe
GM
199*** Emacs preserves the SELinux file context when backing up, and
200optionally when copying files. To this end, copy-file has an extra
201optional argument, and backup-buffer and friends include the SELinux
202context in their return values.
b7d65a5f
GM
203
204*** The new functions file-selinux-context and set-file-selinux-context
205get and set the SELinux context of a file.
206
a5bee597
MA
207*** Tramp offers handlers for file-selinux-context and set-file-selinux-context
208for remote machines which support SELinux.
209
a4180391
PE
210+++
211** The function format-time-string now supports the %N directive, for
212higher-resolution time stamps.
213
9c524fcb 214** The function kill-emacs is now run upon receipt of the signals SIGTERM
383ebd15 215and SIGHUP, and upon SIGINT in batch mode.
9c524fcb
GM
216
217** kill-emacs-hook is now also run in batch mode.
63c72eeb
GM
218If you have code that adds something to kill-emacs-hook, you should
219consider if it is still appropriate to add it in the noninteractive case.
9c524fcb 220
79ce172a 221** New scrolling commands `scroll-up-command' and `scroll-down-command'
0a19a6f8
JB
222(bound to C-v/[next] and M-v/[prior]) do not signal errors at top/bottom
223of buffer at first key-press (instead move to top/bottom of buffer)
7b05466f 224when a new variable `scroll-error-top-bottom' is non-nil.
79ce172a 225
5a97d2da
JL
226** New scrolling commands `scroll-up-line' and `scroll-down-line'
227scroll a line instead of full screen.
228
a4b000fb 229** New property `scroll-command' should be set on a command's symbol to
b2957ea8 230define it as a scroll command affected by `scroll-preserve-screen-position'.
9013a7f8 231
d0f69533
EZ
232+++
233** If you customize `scroll-conservatively' to a value greater than 100,
234Emacs will never recenter point in the window when it scrolls due to
235cursor motion commands or commands that move point (e.f., `M-g M-g').
236Previously, you needed to use `most-positive-fixnum' as the value of
237`scroll-conservatively' to achieve the same effect.
238
239---
240** ``Aggressive'' scrolling now honors the scroll margins.
241If you customize `scroll-up-aggressively' or
242`scroll-down-aggressively' and move point off the window, Emacs now
243scrolls the window so as to avoid positioning point inside the scroll
244margin.
245
f1a5d776
CY
246** Trash changes
247
248*** `delete-by-moving-to-trash' now only affects commands that specify
249trashing. This avoids inadvertently trashing temporary files.
250
251*** Calling `delete-file' or `delete-directory' with a prefix argument
252now forces true deletion, regardless of `delete-by-moving-to-trash'.
253
f0bf7c8e
JL
254** New option `list-colors-sort' defines the color sort order
255for `list-colors-display'.
256
44198b6e
CY
257** An Emacs Lisp package manager is now included.
258This is a convenient way to download and install additional packages,
42d9cffa 259from a package repository at elpa.gnu.org.
cb6c4991
CY
260
261*** `M-x list-packages' shows a list of packages, which can be
262selected for installation.
263
264*** New command `describe-package', bound to `C-h P'.
44198b6e
CY
265
266*** By default, all installed packages are loaded and activated
267automatically when Emacs starts up. To disable this, set
268`package-enable-at-startup' to nil. To change which packages are
269loaded, customize `package-load-list'.
270
d221e780
CO
271** An Emacs Lisp testing tool is now included.
272Emacs Lisp developers can use this tool to write automated tests for
273their code. See the ERT info manual for details.
274
f065864f
CY
275** Custom Themes
276
277*** `M-x customize-themes' lists Custom themes which can be enabled.
278
782b5e8d
CY
279*** New option `custom-theme-load-path' is the load path for themes.
280Emacs no longer looks for custom themes in `load-path'. The default
281is to search in `custom-theme-directory', followed by a built-in theme
282directory named "themes/" in `data-directory'.
283
b7617f6d
CY
284*** New option `custom-safe-themes' records known-safe theme files.
285If a theme is not in this list, Emacs queries before loading it, and
286offers to save the theme to `custom-safe-themes' automatically. By
287default, all themes included in Emacs are treated as safe.
278f6845 288
4ddf410a
MA
289** The user option `remote-file-name-inhibit-cache' controls whether
290the remote file-name cache is used for read access.
291
b8f82dc1
GM
292+++
293** The use of a "mode: minor" specification in a file local variables section
294to enable a minor-mode is deprecated. Instead, use "eval: (minor-mode)".
295
17284e30
GM
296** The standalone programs lib-src/digest-doc and sorted-doc have been
297replaced with Lisp commands `doc-file-to-man' and `doc-file-to-info'.
298
c136e5cd
GM
299---
300** The standalone program `fakemail' has been removed.
301If you need it, feedmail.el ought to provide a superset of the functionality.
302
f13183cf
CY
303** The variable `focus-follows-mouse' now always defaults to nil.
304
42d4bcc8
LL
305** Function `sha1' is now implemented in C for speed.
306The elisp implementation sha1.el is removed. Feature sha1 is provided
307by default.
308
0bfd685e 309\f
eb199145 310* Editing Changes in Emacs 24.1
b350bdf2 311
892777ba
CY
312** Search changes
313
314+++
315*** C-y in Isearch is now bound to isearch-yank-kill, instead of
316isearch-yank-line.
317
25666126
LL
318---
319*** M-y in Isearch is now bound to isearch-yank-pop, instead of
320isearch-yank-kill.
321
892777ba
CY
322+++
323*** M-s C-e in Isearch is now bound to isearch-yank-line.
324
ea4f7750
GM
325+++
326** There is a new command `count-words-region', which does what you expect.
327
67027b49 328** completion-at-point now handles tags and semantic completion.
a982c7ec 329
d74cba8f
MA
330** The default value of `backup-by-copying-when-mismatch' is now t.
331
1c708c1a
CY
332** The command `just-one-space' (C-SPC), if given a negative argument,
333also deletes newlines around point.
334
b9229673
CY
335** Deletion changes
336
337*** New option `delete-active-region'.
338If non-nil, C-d, [delete], and DEL delete the region if it is active
339and no prefix argument is given. If set to `kill', these commands
340kill instead.
341
342*** New command `delete-forward-char', bound to C-d and [delete].
42d9cffa
CY
343This is meant for interactive use, and obeys `delete-active-region'.
344The command `delete-char' does not obey `delete-active-region'.
b9229673
CY
345
346*** `delete-backward-char' is now a Lisp function.
347Apart from obeying `delete-active-region', its behavior is unchanged.
348However, the byte compiler now warns if it is called from Lisp; you
349should use delete-char with a negative argument instead.
350
351*** The option `mouse-region-delete-keys' has been deleted.
352
f9d71b42
CY
353** Selection changes.
354
b1ab31ae
CY
355The default handling of clipboard and primary selections was changed
356to conform with modern X applications. In short, most commands for
357killing and yanking text now use the clipboard, while mouse commands
358use the primary selection.
359
360In the following, we provide a list of these changes, followed by a
361list of steps to get the old behavior back if you prefer that.
362
363*** `mouse-drag-copy-region' now defaults to nil.
364*** `select-active-regions' now defaults to t.
365Merely selecting text (e.g. with drag-mouse-1) no longer puts it in
366the kill-ring. The selected text is put in the primary selection, if
367the system possesses a separate primary selection facility (e.g. X).
368
369**** `select-active-regions' also accepts a new value, `only'.
370This means to only set the primary selection for temporarily active
371regions (usually made by mouse-dragging or shift-selection);
372"ordinary" active regions, such as those made with C-SPC followed by
373point motion, do not alter the primary selection.
374
375*** mouse-2 is now bound to `mouse-yank-primary'.
376This pastes from the primary selection, ignoring the kill-ring.
377Previously, mouse-2 was bound to `mouse-yank-at-click'.
378
379*** `x-select-enable-clipboard' now defaults to t on all platforms.
380*** `x-select-enable-primary' now defaults to nil.
381Thus, commands that kill text or copy it to the kill-ring (such as
382M-w, C-w, and C-k) also use the clipboard---not the primary selection.
383
384**** The "Copy", "Cut", and "Paste" items in the "Edit" menu are now
385exactly equivalent to, respectively M-w, C-w, and C-y.
386
387**** Note that on MS-Windows, `x-select-enable-clipboard' was already
388non-nil by default, as Windows does not support the primary selection
389between applications.
390
391*** To return to the previous behavior, do the following:
392
104c2fe9 393**** Change `select-active-regions' to nil.
b1ab31ae
CY
394**** Change `mouse-drag-copy-region' to t.
395**** Change `x-select-enable-primary' to t (on X only).
396**** Change `x-select-enable-clipboard' to nil.
397**** Bind `mouse-yank-at-click' to mouse-2.
f9d71b42 398
084e6df3
JD
399*** Support for X cut buffers has been removed.
400
1dd3c2d9
CY
401*** Support for X clipboard managers has been added.
402
4b80f674
CY
403**** To inhibit use of the clipboard manager, set
404`x-select-enable-clipboard-manager' to nil.
405
99f053cf
JA
406** New command `rectangle-number-lines', bound to `C-x r N', numbers
407the lines in the current rectangle. With an prefix argument, this
408prompts for a number to count from and for a format string.
409
70436396
MA
410** The command shell prompts for the shell path name, when the default
411directory is a remote file name and neither environment variable
412$ESHELL nor variable `explicit-shell-file-name' is set.
413
9bae34bf 414\f
eb199145 415* Changes in Specialized Modes and Packages in Emacs 24.1
efeb796b 416
c0a193ea
SM
417** comint and modes derived from it use the generic completion code.
418
d9c54a06
CY
419** Compilation mode
420
421*** Compilation mode can be used without font-lock-mode.
9ffae6d0
SM
422`compilation-parse-errors-function' is now obsolete.
423
d9c54a06
CY
424*** `compilation-filter-start' is let-bound to the start of the text
425inserted by the compilation filter function, when calling
426compilation-filter-hook.
427
4d0143e6
JA
428** The Landmark game is now invoked with `landmark', not `lm'.
429
04380ff1 430** Prolog mode has been completely revamped, with lots of additional
86485587 431functionality such as more intelligent indentation, electricity, support for
04380ff1
SM
432more variants, including Mercury, and a lot more.
433
78835dd0
SM
434** shell-mode can track your cwd by reading it from your prompt.
435Just set shell-dir-cookie-re to an appropriate regexp.
436
cbf83ce9
SM
437** Modula-2 mode provides auto-indentation.
438
b7c3692a
RW
439** BibTeX mode
440
34699b85
RW
441*** New command `bibtex-search-entries' bound to C-c C-a.
442
b7c3692a
RW
443*** New `bibtex-entry-format' option `sort-fields', disabled by default.
444
022fe7ce
RW
445*** New variable `bibtex-search-entry-globally'.
446
b879a6e2
SM
447** latex-electric-env-pair-mode keeps \begin..\end matched on the fly.
448
360ac530 449** FIXME: xdg-open for browse-url and reportbug, 2010/08.
0ac3effe 450
b3671a51
JL
451** Archive Mode has basic support to browse 7z archives.
452
876d1684 453** browse-url has gotten a new variable that is used for mailto: URLs,
0a19a6f8 454`browse-url-mailto-function', which defaults to `browse-url-mail'.
876d1684 455
7deebf1b
LMI
456** `url-queue-retrieve' downloads web pages asynchronously, but allow
457controlling the degree of parallelism.
458
817b48a7
GM
459** Directory local variables can apply to file-less buffers, in certain modes
460(eg dired, vc-dir, log-edit). For example, adding
461"(diff-mode . ((mode . whitespace)))" to your .dir-locals.el file,
462will turn on `whitespace-mode' for *vc-diff* buffers. Modes should
463call `hack-dir-local-variables-non-file-buffer' to support this.
464
6640b281
GM
465+++
466** You can prevent directory local variables from applying to subdirectories.
467Add an element (subdirs . nil) to the alist portion of any variables
468settings to indicate said section should not be applied to subdirectories.
469
8a8d54cd
VD
470** ERC changes
471
472*** New vars `erc-autojoin-timing' and `erc-autojoin-delay'.
473If the value of `erc-autojoin-timing' is 'ident, ERC autojoins after a
474successful NickServ identification, or after `erc-autojoin-delay'
475seconds. The default value, 'ident, means to autojoin immediately
476after connecting.
477
5c0c0f77
LMI
478*** New variable `erc-coding-system-precedence': If we use `undecided'
479as the server coding system, this variable will then be consulted.
480The default is to decode strings that can be decoded as utf-8 as
481utf-8, and do the normal `undecided' decoding for the rest.
482
c0e505e5
CY
483** Eshell changes
484
485*** The default value of eshell-directory-name is a directory named
486"eshell" in `user-emacs-directory'. If the old "~/.eshell/" directory
487exists, that is used instead.
488
27d3cd56
CY
489** In ido-mode, C-v is no longer bound to ido-toggle-vc.
490The reason is that this interferes with cua-mode.
491
c1e25821 492** partial-completion-mode is now obsolete.
79ccd68f
SM
493You can get a comparable behavior with:
494(setq completion-styles '(partial-completion initials))
495(setq completion-pcm-complete-word-inserts-delimiters t)
c1e25821 496
18c812bd 497** mpc.el: Can use pseudo tags of the form tag1|tag2 as a union of two tags.
b2957ea8 498
1d83b0e9
GM
499** server can listen on a specific port using the server-port option.
500
cf16af42
GM
501** Calendar, Diary, and Appt
502
548d0a63
GM
503+++
504*** Diary entries can contain non-printing `comments'.
505See the variable `diary-comment-start'.
506
5006e634
GM
507+++
508*** Appointments can specify their individual warning times.
509See the variable `appt-warning-time-regexp'.
510
d306b4da 511+++
7454f200
GM
512*** New function `diary-hebrew-birthday'.
513
e565dd37
GM
514---
515*** Elements of `calendar-day-abbrev-array' and `calendar-month-abbrev-array'
516may no longer be nil, but must all be strings.
517
cf16af42
GM
518---
519*** The obsolete (since Emacs 22.1) method of enabling the appt package
520by adding appt-make-list to diary-hook has been removed. Use appt-activate.
521
522---
523*** Some appt variables (obsolete since Emacs 22.1) have been removed:
524appt-issue-message (use the function appt-activate)
525appt-visible/appt-msg-window (use the variable appt-display-format)
526
527---
528*** Some diary function aliases (obsolete since Emacs 22.1) have been removed:
529view-diary-entries, list-diary-entries, show-all-diary-entries
530
52834b6b
CY
531** Customize
532
533*** Customize buffers now contain a search field.
534The search is performed using `customize-apropos'.
42d9cffa 535To turn off the search field, set custom-search-field to nil.
52834b6b
CY
536
537*** Custom options now start out hidden if at their default values.
538Use the arrow to the left of the option name to toggle visibility.
539
540*** custom-buffer-sort-alphabetically now defaults to t.
541
542*** The color widget now has a "Choose" button, which allows you to
543choose a color via list-colors-display.
544
f5d6548a
JL
545** Dired-x
546
547*** dired-jump and dired-jump-other-window called with a prefix argument
548read a file name from the minibuffer instead of using buffer-file-name.
549
817b48a7
GM
550+++
551*** The `dired local variables' feature provided by Dired-x is obsolete.
552The standard directory local variables feature replaces it.
8117868f 553
7492acc9
MM
554** SQL Mode enhancements.
555
9250002f
MM
556*** `sql-dialect' is a synonym for `sql-product'.
557
74790210 558*** Added ability to login with a port on MySQL and Postgres.
7492acc9 559The custom variable `sql-port' can be specified for connection to
74790210
MM
560MySQL or Postgres servers. By default, the port is not listed in
561either login parameter, but will be added to the command line if set
562to a non-zero value.
7492acc9 563
9250002f
MM
564*** Dynamic selection of product in an SQL interactive session.
565If you use `sql-product-interactive' to start an SQL interactive
566session it uses the current value of `sql-product'. Preceding the
567invocation with C-u will force it to ask for the product before
568creating the session.
569
570*** Renaming a SQL interactive buffer when it is created.
571Prefixing the SQL interactive commands (`sql-sqlite', `sql-postgres',
572`sql-mysql', etc.) with C-u will force a new interactive session to be
573started and will prompt for the new name. This will reduce the need
574for `sql-rename-buffer' is most common use cases.
575
3bd2cfef
MM
576*** Command continuation prompts in SQL interactive mode are suppressed.
577Multiple line commands in SQL interactive mode, generate command
578continuation prompts which needlessly confuse the output. These
579prompts are now filtered out from the output. This change impacts
580multiple line SQL statements entered with C-j between each line,
581statements yanked into the buffer and statements sent with
582`sql-send-*' functions.
583
7492acc9
MM
584*** Custom variables control prompting for login parameters.
585Each supported product has a custom variable `sql-*-login-params'
586which is a list of the parameters to be prompted for before a
587connection is established.
588
74790210
MM
589The lists consist of the following five tokens: `user', `password',
590`database', `server', and `port'. The order in which they appear is
591the order in which they are prompted. The tokens symbols can be
592replaced by a sublist starting with the token and followed by a plist
593which control the prompting for values. The tokens `user',
594`database', and `server' each can take a property of :default which
595specifies the value to be used if no value is entered. The
596`database', `server', and `port' tokens handle the :completion
597property which restricts the entry to either one of the values in the
598list or to one of the values returned by the function provided as the
599property value. The `database' and `server' tokens also accept the
600:file property whose value is a regexp to identify useful file names.
601
602 (user :default DEF)
603 (database :default DEF
604 :file FILEPAT
605 :completion COMPLETE)
606 (server :default DEF
607 :file FILEPAT
608 :completion COMPLETE)
609
610The FILEPAT when :file is specified is a regexp that will match valid
611file names (without the directory portion). Generally these strings
612will be of the form ".+\.SUF" where SUF is the desired file suffix.
613
614When :completion is specified, the COMPLETE corresponds to the
615PREDICATE argument to the `completing-read' function (a list of
616possible values or a function returning such a list).
5474c40f 617
30c4d8dc
MM
618*** Added `sql-connection-alist' to record login parameter values.
619An alist for recording different username, database and server
620values. If there are multiple databases that you connect to the
621parameters needed can be stored in this alist.
622
623For example, the following might be set in the user's init.el:
624
625 (setq sql-connection-alist
626 '((dev (sql-product 'sqlite)
627 (sql-database "/home/mmaug/dev.db"))
628 (prd (sql-product 'oracle)
629 (sql-user "mmaug")
630 (sql-database "iprd2a"))))
631
632This defines two connections named "dev" and "prd".
633
634*** Added `sql-connect' to use predefined connections.
635Sets the login parameters based on the values in the
636`sql-connection-alist' and start a SQL interactive session. Any
637values specified in the connection will not be prompted for.
638
639In the example above, if the user were to invoke M-x sql-connect, they
640would be prompted for the connection. The user can respond with
641either "dev" or "prd". The "dev" connection would connect to the
642SQLite database without prompting; the "prd" connection would prompt
643for the users password and then connect to the Oracle database.
644
d26b0ea9 645**** Added SQL->Start... submenu when connections are defined.
b2957ea8 646When connections have been defined, there is a submenu available that
d26b0ea9
MM
647allows the user to select one to start a SQLi session. The "Start
648SQLi Session" item moves to the "Start..." submenu when cnnections
649have been defined.
650
651**** Added "Save Connection" menu item in SQLi buffers.
652When a SQLi session is not started by a connection then
653`sql-save-connection' will gather the login params specified for the
654session and save them as a new connection.
655
74790210
MM
656*** List database objects and details.
657Once a SQL interactive session has been started, you can get a list of
658the objects in the database and see details of those objects. The
659objects shown and the details available are product specific.
660
661**** List all objects.
662Using `M-x sql-list-all', `C-c C-l a' or selecting "SQL->List all
663objects" will list all the objects in the database. At a minimum it
86485587 664lists the tables and views in the database. Preceding the command by
74790210
MM
665universal argument may provide additional details or extend the
666listing to include other schemas objects. The list will appear in a
667separate window in view-mode.
668
669**** List Table details.
670Using `M-x sql-list-table', `C-c C-l t' or selecting "SQL->List Table
671details" will ask for the name of a database table or view and display
86485587 672the list of columns in the relation. Preceding the command with the
74790210
MM
673universal argument may provide additional details about each column.
674The list will appear in a separate window in view-mode.
675
7492acc9
MM
676*** Added option `sql-send-terminator'.
677When set makes sure that each command sent with `sql-send-*' commands
678are properly terminated and submitted to the SQL processor.
679
680*** Added option `sql-oracle-scan-on'.
681When set commands sent to Oracle's SQL*Plus are scanned for strings
30c4d8dc
MM
682starting with an ampersand and the user is asked for replacement text.
683In general, the SQL*Plus option SCAN should always be set OFF under
684SQL interactive mode and this option used in its place.
7492acc9
MM
685
686*** SQL interactive mode will replace tabs with spaces.
86485587 687This prevents the command interpreter for MySQL and Postgres from
7492acc9
MM
688listing object name completions when being sent text via
689`sql-send-*' functions.
690
691*** An API for manipulating SQL product definitions has been added.
692
723ee192
SM
693** sregex.el is now obsolete, since rx.el is a strict superset.
694
6ca94a0b 695** s-region.el and pc-select are now declared obsolete,
86485587 696superseded by shift-select-mode enabled by default in 23.1.
6ca94a0b 697** pc-mode.el is also declared obsolete.
691cf4a0
NR
698** gdb-mi
699
700*** GDB User Interface migrated to GDB Machine Interface and now
701supports multithread non-stop debugging and debugging of several
702threads simultaneously.
703
37221432
MA
704** D-Bus
705
706*** It is possible now, to access alternative buses than the default
707system or session bus.
708
3c3d4f5b
MA
709*** dbus-register-{service,method,property}
710The -method and -property functions do not automatically register
711names anymore.
712
713The new function dbus-register-service registers a service known name
714on a D-Bus without simultaneously registering a property or a method.
412b9ee5 715
459bba37
MA
716** Tramp
717
a808d31f
MA
718*** There exists a new inline access method "ksu" (kerberized su).
719
459bba37 720*** The following access methods are discontinued: "ssh1_old",
ea843702 721"ssh2_old", "scp1_old", "scp2_old", "imap", "imaps" and "fish".
459bba37 722
58f74fe4
MA
723*** The option `ange-ftp-binary-file-name-regexp' has changed its
724default value to "".
725
0c32ce32
CY
726** VC and related modes
727
728*** Support for pulling on distributed version control systems.
659114fd 729The vc-pull command runs a "pull" operation, if it is supported.
0c32ce32 730This updates the current branch from upstream. A prefix argument
659114fd 731means to prompt the user for specifics, e.g. a pull location.
0c32ce32 732
7d93eca9 733**** `vc-update' is now an alias for `vc-pull'.
0c32ce32 734
659114fd 735**** Currently supported by Bzr, Git, and Mercurial.
0c32ce32
CY
736
737*** Support for merging on distributed version control systems.
738The vc-merge command now runs a "merge" operation, if it is supported.
659114fd
CY
739This merges another branch into the current one. This command prompts
740the user for specifics, e.g. a merge source.
0c32ce32 741
33f6cf7b 742**** Currently supported for Bzr, Git, and Mercurial.
0c32ce32 743
d4eb88c7
CY
744*** Log entries in some Log View buffers can be toggled to display a
745longer description by typing RET (log-view-toggle-entry-display).
746In the Log View buffers made by `C-x v L' (vc-print-root-log), you can
747use this to display the full log entry for the revision at point.
748
33f6cf7b 749**** Currently supported for Bzr, Git, and Mercurial.
d4eb88c7
CY
750
751**** Packages using Log View mode can enable this functionality by
752binding `log-view-expanded-log-entry-function' to a suitable function.
753
1c6c854e
CS
754*** New command `vc-ediff' allows visual comparison of two revisions
755of a file similar to `vc-diff', but using ediff backend.
756
0fe719e6
GM
757** Miscellaneous
758
759---
760*** `copyright-fix-years' can optionally convert consecutive years to ranges.
761
5b3e6db8
GM
762*** New command `nato-region' converts text to NATO phonetic alphabet.
763
0f0c1f27
EZ
764*** The new command `info-display-manual' will display an Info manual
765specified by its name. If that manual is already visited in some Info
766buffer within the current session, the command will display that
767buffer. Otherwise, it will load the manual and display it. This is
768handy if you have many manuals in many Info buffers, and don't
769remember the name of the buffer visiting the manual you want to
770consult.
771
eb199145
GM
772\f
773* New Modes and Packages in Emacs 24.1
d445b3f8 774
60e56523
LL
775** Occur Edit mode applies edits made in *Occur* buffers to the
776original buffers. It is bound to C-x C-q in Occur mode.
777
7100ff98
SM
778** New global minor modes electric-pair-mode, electric-indent-mode,
779and electric-layout-mode.
3b843809 780
a83ec3c9
CY
781** tabulated-list.el provides a generic major mode for tabulated data,
782from which other modes can be derived.
783
d02c9bcd
SM
784** pcase.el provides the ML-style pattern matching macro `pcase'.
785
7725ebb7
MA
786** secrets.el is an implementation of the Secret Service API, an
787interface to password managers like GNOME Keyring or KDE Wallet. The
065f2743
MA
788Secret Service API requires D-Bus for communication. The command
789`secrets-show-secrets' offers a buffer with a visualization of the
790secrets.
7725ebb7 791
f9e78150
MA
792** notifications.el provides an implementation of the Desktop
793Notifications API. It requires D-Bus for communication.
794
12fe5bcc
MA
795** soap-client.el supports access to SOAP web services from Emacs.
796soap-inspect.el is an interactive inspector for SOAP WSDL structures.
797
ad7d6ecb
GM
798** xmodmap-generic-mode for xmodmap files.
799
eb199145
GM
800\f
801* Incompatible Lisp Changes in Emacs 24.1
6dfcbe31 802
fa6996bc
EZ
803---
804** `char-direction-table' and the associated function `char-direction'
805were deleted. They were buggy and inferior to the new support of
806bidirectional editing introduced in Emacs 24. If you need the
807bidirectional properties of a character, use `get-char-code-property'
808with the last argument `bidi-class'.
809
470d996d
TV
810** `copy-directory' now copies the source directory as a subdirectory
811of the target directory, if the latter is an existing directory. The
812new optional arg COPY-CONTENTS, if non-nil, makes the function copy
813the contents directly into a pre-existing target directory.
814
25ca2e61
CY
815** `compose-mail' now accepts an optional 8th arg, RETURN-ACTION, and
816passes it to the mail user agent function. This argument specifies an
817action for returning to the caller after finishing with the mail.
818This is currently used by Rmail to delete a mail window.
819
9173a8fb
CY
820** For mouse click input events in the text area, the Y pixel
821coordinate in the POSITION list now counts from the top of the text
822area, excluding any header line. Previously, it counted from the top
823of the header line.
824
c4d17d50
SM
825** Remove obsolete name `e' (use `float-e' instead).
826
288cf4e9
SM
827** A backquote not followed by a space is now always treated as new-style.
828
fd5c9dfa 829** Test for special mode-class was moved from view-file to view-buffer.
288cf4e9
SM
830FIXME: This only says what was changed, but not what are the
831programmer-visible consequences.
fd5c9dfa 832
3b7e1d5f 833** Passing a nil argument to a minor mode function now turns the mode
0a19a6f8 834ON unconditionally.
6431f2e6
CY
835
836** During startup, Emacs no longer adds entries for `menu-bar-lines'
0a19a6f8
JB
837and `tool-bar-lines' to `default-frame-alist' and `initial-frame-alist'.
838With these alist entries omitted, `make-frame' checks the value of the
839variable `menu-bar-mode'/`tool-bar-mode' to determine whether to create
840a menu-bar or tool-bar, respectively. If the alist entries are added,
841they override the value of `menu-bar-mode'/`tool-bar-mode'.
6431f2e6 842
fe0aa820
CY
843** Regions created by mouse dragging are now normal active regions,
844similar to the ones created by shift-selection. In previous Emacs
845versions, these regions were delineated by `mouse-drag-overlay', which
846has now been removed.
d6d8ee7a 847
4583e796
GM
848** cl.el no longer provides `cl-19'.
849
3226d6ca
GM
850** The following functions and aliases, obsolete since at least Emacs 21.1,
851have been removed:
852comint-kill-output, decompose-composite-char, outline-visible,
853internal-find-face, internal-get-face, frame-update-faces,
854frame-update-face-colors, x-frob-font-weight, x-frob-font-slant,
855x-make-font-bold, x-make-font-demibold, x-make-font-unbold
856x-make-font-italic, x-make-font-oblique, x-make-font-unitalic
857x-make-font-bold-italic, mldrag-drag-mode-line, mldrag-drag-vertical-line,
922ad43e
GM
858iswitchb-default-keybindings, char-bytes, isearch-return-char,
859make-local-hook
3226d6ca
GM
860
861** The following variables and aliases, obsolete since at least Emacs 21.1,
862have been removed:
6aecca99
GM
863checkdoc-minor-keymap, vc-header-alist, directory-sep-char,
864font-lock-defaults-alist
3226d6ca 865
7b0e3048
GM
866** The following files, obsolete since at least Emacs 21.1, have been removed:
867sc.el, x-menu.el, rnews.el, rnewspost.el
868
33658d4e
CY
869** FIXME finder-inf.el changes.
870
eb199145
GM
871\f
872* Lisp changes in Emacs 24.1
9097e8af 873
a2a25d24
SM
874** Completion
875*** New variable completion-extra-properties used to specify extra properties
876of the current completion:
877- :annotate-function, same as the old completion-annotate-function.
878- :exit-function, function to call after completion took place.
879
880*** Functions on completion-at-point-functions can return any of the properties
881valid for completion-extra-properties.
882
883*** completion-annotate-function is obsolete.
884
620c53a6
SM
885*** New `metadata' method for completion tables. The metadata thus returned
886can specify various details of the data returned by `all-completions':
887- `category' is the kind of objects returned (e.g., `buffer', `file', ...),
888 used to select a style in completion-category-overrides.
889- `annotation-function' to add annotations in *Completions*.
890- `display-sort-function' to specify how to sort entries in *Completions*.
891- `cycle-sort-function' to specify how to sort entries when cycling.
892
f042970d 893** `glyphless-char-display' can now distinguish between graphical and
16a43933
CY
894text terminal display, via a char-table entry that is a cons cell.
895
da91b5f2
CY
896** `open-network-stream' can now be used to open an encrypted stream.
897It now accepts an optional `:type' parameter for initiating a TLS
898connection, directly or via STARTTLS. To do STARTTLS, additional
899parameters (`:end-of-command', `:success', `:capabilities-command')
900must also be supplied.
901
03408648
SM
902** Code can now use lexical scoping by default instead of dynamic scoping.
903The `lexical-binding' variable lets code use lexical scoping for local
904variables. It is typically set via file-local variables, in which case it
905applies to all the code in that file.
906
907*** `eval' takes a new optional argument `lexical' to choose the new lexical
908binding instead of the old dynamic binding mode.
909
910*** Lexically scoped interpreted functions are represented with a new form
911of function value which looks like (closure ENV ARGS &rest BODY).
912
913*** New macro `letrec' to define recursive local functions.
914
915*** New function `special-variable-p' to check whether a variable is
916declared as dynamically bound.
917
f6d62986
SM
918** pre/post-command-hook are not reset to nil upon error.
919Instead, the offending function is removed.
920
921** New low-level function run-hook-wrapped.
922
7deebf1b
LMI
923** `server-eval-at' is provided to allow evaluating forms on different
924Emacs server instances.
925
926** `call-process' allows a `(:file "file")' spec to redirect STDOUT to
927a file.
928
53cfe624 929** byte-compile-disable-print-circle is obsolete.
78f64af0 930** deferred-action-list and deferred-action-function are obsolete.
e7f7fbaa
SM
931** Removed the stack-trace-on-error variable.
932Also the debugger can now "continue" from an error, which means it will jump
933to the error handler as if the debugger had not been invoked instead of
934jumping all the way to the top-level.
935
3ef01959
CY
936** New function `read-char-choice' reads a restricted set of characters,
937discarding any inputs not inside the set.
938
2e288d54
JB
939** `image-library-alist' is renamed to `dynamic-library-alist'.
940The variable is now used to load all kind of supported dynamic libraries,
941not just image libraries. The previous name is still available as an
942obsolete alias.
943
cf38dd42
SM
944** New variable syntax-propertize-function to set syntax-table properties.
945Replaces font-lock-syntactic-keywords which are now obsolete.
946This allows syntax-table properties to be set independently from font-lock:
947just call syntax-propertize to make sure the text is propertized.
948Together with this new variable come a new hook
949syntax-propertize-extend-region-functions, as well as two helper functions:
950syntax-propertize-via-font-lock to reuse old font-lock-syntactic-keywords
951as-is; and syntax-propertize-rules which provides a new way to specify
952syntactic rules.
953
a2e5caf7
SM
954** New hook post-self-insert-hook run at the end of self-insert-command.
955
7cf78aac 956+++
c5683ceb 957** Syntax tables support a new "comment style c" additionally to style b.
4e2db1fe 958** frame-local variables cannot be let-bound any more.
10dcc561 959** prog-mode is a new major-mode meant to be the parent of programming mode.
f44379e7
SM
960** define-minor-mode accepts a new keyword :variable.
961
b2957ea8 962** `delete-file' and `delete-directory' now accept optional arg TRASH.
f1a5d776
CY
963Trashing is performed if TRASH and `delete-by-moving-to-trash' are
964both non-nil. Interactively, TRASH defaults to t, unless a prefix
965argument is supplied (see Trash changes, above).
53967e09 966
8f92b8ad
SM
967** buffer-substring-filters is obsoleted by filter-buffer-substring-functions.
968
9317e499
CY
969** `facemenu-read-color' is now an alias for `read-color'.
970The command `read-color' now requires a match for a color name or RGB
971triplet, instead of signalling an error if the user provides a invalid
972input.
973
4039c786
CY
974** Tool-bars can display separators.
975Tool-bar separators are handled like menu separators in menu-bar maps,
94975270 976i.e. via menu entries of the form `(menu-item "--")'.
9317e499 977
00fe2df1
JL
978** Image API
979
980*** When the image type is one of listed in `image-animated-types'
1546c559 981and the number of sub-images in the image is more than one, then the
00fe2df1
JL
982new function `create-animated-image' creates an animated image where
983sub-images are displayed successively with the duration defined by
984`image-animate-max-time' and the delay between sub-images defined
985by the Graphic Control Extension of the image.
986
1546c559
JL
987*** `image-extension-data' is renamed to `image-metadata'.
988
71c17aec
LMI
989** XML and HTML parsing
990
991*** If Emacs is compiled with libxml2 support (which is the default),
4b9832a6 992two new Emacs Lisp-level functions are defined:
84156e94
MA
993`libxml-parse-html-region' (which will parse "real world" HTML)
994and `libxml-parse-xml-region' (which parses XML). Both return an
4b9832a6
CY
995Emacs Lisp parse tree.
996
997FIXME: These should be front-ended by xml.el.
998
e2574f2c
TZ
999** GnuTLS
1000
1001*** Emacs can be compiled with libgnutls support
1002This is the default. You will then be able to use the functionality
1003in gnutls.el, namely the `open-gnutls-stream' and `gnutls-negotiate'
1004functions. It's easiest to use these functions through
1005`open-network-stream' because it can upgrade connections through
1006STARTTLS opportunistically or use plain SSL, depending on your needs.
1007
1008Only versions 2.8.x and higher or GnuTLS have been tested.
1009
1010*** gnutls-log-level
1011Set `gnutls-log-level' higher than 0 to get debug output. 1 is for
1012important messages, 2 is for debug data, and higher numbers are as per
1013the GnuTLS logging conventions. The output is in *Messages*.
71c17aec 1014
a6020335
MH
1015** Isearch
1016
1017*** New hook `isearch-update-post-hook' that runs in `isearch-update'.
1018
9326ba26
CY
1019** Progress reporters can now "spin".
1020The MIN-VALUE and MAX-VALUE arguments of `make-progress-reporter' can
1021now be nil, or omitted. This makes a "non-numeric" reporter. Each
1022time you call `progress-reporter-update' on that progress reporter,
1023with a nil or omitted VALUE argument, the reporter message is
1024displayed with a "spinning bar".
1025
3e214b50
JB
1026** New variable `revert-buffer-in-progress-p' is true while a buffer is
1027being reverted, even if the buffer has a local `revert-buffer-function'.
1028
638f053a
JB
1029** New variables `delayed-warnings-list' and `delayed-warnings-hook' allow
1030deferring warnings until the main command loop is executed.
1031
e145f188
GM
1032+++
1033** `set-auto-mode' now respects mode: local variables at the end of files,
1034as well as those in the -*- line.
1035
eb199145
GM
1036\f
1037* Changes in Emacs 24.1 on non-free operating systems
d53a60a6 1038
0a19a6f8 1039** New configure.bat option --enable-checking builds Emacs with extra
04779484
JB
1040runtime checks.
1041
e3aef5c6 1042** New configure.bat option --distfiles to specify files to be
0a19a6f8 1043included in binary distribution.
e3aef5c6 1044
e2574f2c
TZ
1045** New configure.bat option --without-gnutls to disable automatic
1046GnuTLS detection.
1047
1048** New configure.bat option --lib for general library linkage, works
1049with the USER_LIBS build variable.
1050
0a19a6f8 1051** New make target `dist' to create binary distribution for MS Windows.
e3aef5c6 1052
05197f40 1053\f
a933dad1 1054----------------------------------------------------------------------
5b87ad55 1055This file is part of GNU Emacs.
a933dad1 1056
ab73e885 1057GNU Emacs is free software: you can redistribute it and/or modify
5b87ad55 1058it under the terms of the GNU General Public License as published by
ab73e885
GM
1059the Free Software Foundation, either version 3 of the License, or
1060(at your option) any later version.
5b87ad55
GM
1061
1062GNU Emacs is distributed in the hope that it will be useful,
1063but WITHOUT ANY WARRANTY; without even the implied warranty of
1064MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1065GNU General Public License for more details.
a933dad1 1066
5b87ad55 1067You should have received a copy of the GNU General Public License
ab73e885 1068along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
a933dad1 1069
05197f40 1070\f
a933dad1
DL
1071Local variables:
1072mode: outline
1073paragraph-separate: "[ \f]*$"
1074end: