Handle errors when saving to clipboard manager (Bug#8779).
[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
b879a6e2
SM
439** latex-electric-env-pair-mode keeps \begin..\end matched on the fly.
440
360ac530 441** FIXME: xdg-open for browse-url and reportbug, 2010/08.
0ac3effe 442
b3671a51
JL
443** Archive Mode has basic support to browse 7z archives.
444
876d1684 445** browse-url has gotten a new variable that is used for mailto: URLs,
0a19a6f8 446`browse-url-mailto-function', which defaults to `browse-url-mail'.
876d1684 447
7deebf1b
LMI
448** `url-queue-retrieve' downloads web pages asynchronously, but allow
449controlling the degree of parallelism.
450
817b48a7
GM
451** Directory local variables can apply to file-less buffers, in certain modes
452(eg dired, vc-dir, log-edit). For example, adding
453"(diff-mode . ((mode . whitespace)))" to your .dir-locals.el file,
454will turn on `whitespace-mode' for *vc-diff* buffers. Modes should
455call `hack-dir-local-variables-non-file-buffer' to support this.
456
6640b281
GM
457+++
458** You can prevent directory local variables from applying to subdirectories.
459Add an element (subdirs . nil) to the alist portion of any variables
460settings to indicate said section should not be applied to subdirectories.
461
8a8d54cd
VD
462** ERC changes
463
464*** New vars `erc-autojoin-timing' and `erc-autojoin-delay'.
465If the value of `erc-autojoin-timing' is 'ident, ERC autojoins after a
466successful NickServ identification, or after `erc-autojoin-delay'
467seconds. The default value, 'ident, means to autojoin immediately
468after connecting.
469
5c0c0f77
LMI
470*** New variable `erc-coding-system-precedence': If we use `undecided'
471as the server coding system, this variable will then be consulted.
472The default is to decode strings that can be decoded as utf-8 as
473utf-8, and do the normal `undecided' decoding for the rest.
474
c0e505e5
CY
475** Eshell changes
476
477*** The default value of eshell-directory-name is a directory named
478"eshell" in `user-emacs-directory'. If the old "~/.eshell/" directory
479exists, that is used instead.
480
27d3cd56
CY
481** In ido-mode, C-v is no longer bound to ido-toggle-vc.
482The reason is that this interferes with cua-mode.
483
c1e25821 484** partial-completion-mode is now obsolete.
79ccd68f
SM
485You can get a comparable behavior with:
486(setq completion-styles '(partial-completion initials))
487(setq completion-pcm-complete-word-inserts-delimiters t)
c1e25821 488
18c812bd 489** mpc.el: Can use pseudo tags of the form tag1|tag2 as a union of two tags.
b2957ea8 490
1d83b0e9
GM
491** server can listen on a specific port using the server-port option.
492
cf16af42
GM
493** Calendar, Diary, and Appt
494
548d0a63
GM
495+++
496*** Diary entries can contain non-printing `comments'.
497See the variable `diary-comment-start'.
498
5006e634
GM
499+++
500*** Appointments can specify their individual warning times.
501See the variable `appt-warning-time-regexp'.
502
d306b4da 503+++
7454f200
GM
504*** New function `diary-hebrew-birthday'.
505
e565dd37
GM
506---
507*** Elements of `calendar-day-abbrev-array' and `calendar-month-abbrev-array'
508may no longer be nil, but must all be strings.
509
cf16af42
GM
510---
511*** The obsolete (since Emacs 22.1) method of enabling the appt package
512by adding appt-make-list to diary-hook has been removed. Use appt-activate.
513
514---
515*** Some appt variables (obsolete since Emacs 22.1) have been removed:
516appt-issue-message (use the function appt-activate)
517appt-visible/appt-msg-window (use the variable appt-display-format)
518
519---
520*** Some diary function aliases (obsolete since Emacs 22.1) have been removed:
521view-diary-entries, list-diary-entries, show-all-diary-entries
522
52834b6b
CY
523** Customize
524
525*** Customize buffers now contain a search field.
526The search is performed using `customize-apropos'.
42d9cffa 527To turn off the search field, set custom-search-field to nil.
52834b6b
CY
528
529*** Custom options now start out hidden if at their default values.
530Use the arrow to the left of the option name to toggle visibility.
531
532*** custom-buffer-sort-alphabetically now defaults to t.
533
534*** The color widget now has a "Choose" button, which allows you to
535choose a color via list-colors-display.
536
f5d6548a
JL
537** Dired-x
538
539*** dired-jump and dired-jump-other-window called with a prefix argument
540read a file name from the minibuffer instead of using buffer-file-name.
541
817b48a7
GM
542+++
543*** The `dired local variables' feature provided by Dired-x is obsolete.
544The standard directory local variables feature replaces it.
8117868f 545
7492acc9
MM
546** SQL Mode enhancements.
547
9250002f
MM
548*** `sql-dialect' is a synonym for `sql-product'.
549
74790210 550*** Added ability to login with a port on MySQL and Postgres.
7492acc9 551The custom variable `sql-port' can be specified for connection to
74790210
MM
552MySQL or Postgres servers. By default, the port is not listed in
553either login parameter, but will be added to the command line if set
554to a non-zero value.
7492acc9 555
9250002f
MM
556*** Dynamic selection of product in an SQL interactive session.
557If you use `sql-product-interactive' to start an SQL interactive
558session it uses the current value of `sql-product'. Preceding the
559invocation with C-u will force it to ask for the product before
560creating the session.
561
562*** Renaming a SQL interactive buffer when it is created.
563Prefixing the SQL interactive commands (`sql-sqlite', `sql-postgres',
564`sql-mysql', etc.) with C-u will force a new interactive session to be
565started and will prompt for the new name. This will reduce the need
566for `sql-rename-buffer' is most common use cases.
567
3bd2cfef
MM
568*** Command continuation prompts in SQL interactive mode are suppressed.
569Multiple line commands in SQL interactive mode, generate command
570continuation prompts which needlessly confuse the output. These
571prompts are now filtered out from the output. This change impacts
572multiple line SQL statements entered with C-j between each line,
573statements yanked into the buffer and statements sent with
574`sql-send-*' functions.
575
7492acc9
MM
576*** Custom variables control prompting for login parameters.
577Each supported product has a custom variable `sql-*-login-params'
578which is a list of the parameters to be prompted for before a
579connection is established.
580
74790210
MM
581The lists consist of the following five tokens: `user', `password',
582`database', `server', and `port'. The order in which they appear is
583the order in which they are prompted. The tokens symbols can be
584replaced by a sublist starting with the token and followed by a plist
585which control the prompting for values. The tokens `user',
586`database', and `server' each can take a property of :default which
587specifies the value to be used if no value is entered. The
588`database', `server', and `port' tokens handle the :completion
589property which restricts the entry to either one of the values in the
590list or to one of the values returned by the function provided as the
591property value. The `database' and `server' tokens also accept the
592:file property whose value is a regexp to identify useful file names.
593
594 (user :default DEF)
595 (database :default DEF
596 :file FILEPAT
597 :completion COMPLETE)
598 (server :default DEF
599 :file FILEPAT
600 :completion COMPLETE)
601
602The FILEPAT when :file is specified is a regexp that will match valid
603file names (without the directory portion). Generally these strings
604will be of the form ".+\.SUF" where SUF is the desired file suffix.
605
606When :completion is specified, the COMPLETE corresponds to the
607PREDICATE argument to the `completing-read' function (a list of
608possible values or a function returning such a list).
5474c40f 609
30c4d8dc
MM
610*** Added `sql-connection-alist' to record login parameter values.
611An alist for recording different username, database and server
612values. If there are multiple databases that you connect to the
613parameters needed can be stored in this alist.
614
615For example, the following might be set in the user's init.el:
616
617 (setq sql-connection-alist
618 '((dev (sql-product 'sqlite)
619 (sql-database "/home/mmaug/dev.db"))
620 (prd (sql-product 'oracle)
621 (sql-user "mmaug")
622 (sql-database "iprd2a"))))
623
624This defines two connections named "dev" and "prd".
625
626*** Added `sql-connect' to use predefined connections.
627Sets the login parameters based on the values in the
628`sql-connection-alist' and start a SQL interactive session. Any
629values specified in the connection will not be prompted for.
630
631In the example above, if the user were to invoke M-x sql-connect, they
632would be prompted for the connection. The user can respond with
633either "dev" or "prd". The "dev" connection would connect to the
634SQLite database without prompting; the "prd" connection would prompt
635for the users password and then connect to the Oracle database.
636
d26b0ea9 637**** Added SQL->Start... submenu when connections are defined.
b2957ea8 638When connections have been defined, there is a submenu available that
d26b0ea9
MM
639allows the user to select one to start a SQLi session. The "Start
640SQLi Session" item moves to the "Start..." submenu when cnnections
641have been defined.
642
643**** Added "Save Connection" menu item in SQLi buffers.
644When a SQLi session is not started by a connection then
645`sql-save-connection' will gather the login params specified for the
646session and save them as a new connection.
647
74790210
MM
648*** List database objects and details.
649Once a SQL interactive session has been started, you can get a list of
650the objects in the database and see details of those objects. The
651objects shown and the details available are product specific.
652
653**** List all objects.
654Using `M-x sql-list-all', `C-c C-l a' or selecting "SQL->List all
655objects" will list all the objects in the database. At a minimum it
86485587 656lists the tables and views in the database. Preceding the command by
74790210
MM
657universal argument may provide additional details or extend the
658listing to include other schemas objects. The list will appear in a
659separate window in view-mode.
660
661**** List Table details.
662Using `M-x sql-list-table', `C-c C-l t' or selecting "SQL->List Table
663details" will ask for the name of a database table or view and display
86485587 664the list of columns in the relation. Preceding the command with the
74790210
MM
665universal argument may provide additional details about each column.
666The list will appear in a separate window in view-mode.
667
7492acc9
MM
668*** Added option `sql-send-terminator'.
669When set makes sure that each command sent with `sql-send-*' commands
670are properly terminated and submitted to the SQL processor.
671
672*** Added option `sql-oracle-scan-on'.
673When set commands sent to Oracle's SQL*Plus are scanned for strings
30c4d8dc
MM
674starting with an ampersand and the user is asked for replacement text.
675In general, the SQL*Plus option SCAN should always be set OFF under
676SQL interactive mode and this option used in its place.
7492acc9
MM
677
678*** SQL interactive mode will replace tabs with spaces.
86485587 679This prevents the command interpreter for MySQL and Postgres from
7492acc9
MM
680listing object name completions when being sent text via
681`sql-send-*' functions.
682
683*** An API for manipulating SQL product definitions has been added.
684
723ee192
SM
685** sregex.el is now obsolete, since rx.el is a strict superset.
686
6ca94a0b 687** s-region.el and pc-select are now declared obsolete,
86485587 688superseded by shift-select-mode enabled by default in 23.1.
6ca94a0b 689** pc-mode.el is also declared obsolete.
691cf4a0
NR
690** gdb-mi
691
692*** GDB User Interface migrated to GDB Machine Interface and now
693supports multithread non-stop debugging and debugging of several
694threads simultaneously.
695
37221432
MA
696** D-Bus
697
698*** It is possible now, to access alternative buses than the default
699system or session bus.
700
3c3d4f5b
MA
701*** dbus-register-{service,method,property}
702The -method and -property functions do not automatically register
703names anymore.
704
705The new function dbus-register-service registers a service known name
706on a D-Bus without simultaneously registering a property or a method.
412b9ee5 707
459bba37
MA
708** Tramp
709
a808d31f
MA
710*** There exists a new inline access method "ksu" (kerberized su).
711
459bba37 712*** The following access methods are discontinued: "ssh1_old",
ea843702 713"ssh2_old", "scp1_old", "scp2_old", "imap", "imaps" and "fish".
459bba37 714
58f74fe4
MA
715*** The option `ange-ftp-binary-file-name-regexp' has changed its
716default value to "".
717
0c32ce32
CY
718** VC and related modes
719
720*** Support for pulling on distributed version control systems.
659114fd 721The vc-pull command runs a "pull" operation, if it is supported.
0c32ce32 722This updates the current branch from upstream. A prefix argument
659114fd 723means to prompt the user for specifics, e.g. a pull location.
0c32ce32 724
7d93eca9 725**** `vc-update' is now an alias for `vc-pull'.
0c32ce32 726
659114fd 727**** Currently supported by Bzr, Git, and Mercurial.
0c32ce32
CY
728
729*** Support for merging on distributed version control systems.
730The vc-merge command now runs a "merge" operation, if it is supported.
659114fd
CY
731This merges another branch into the current one. This command prompts
732the user for specifics, e.g. a merge source.
0c32ce32 733
33f6cf7b 734**** Currently supported for Bzr, Git, and Mercurial.
0c32ce32 735
d4eb88c7
CY
736*** Log entries in some Log View buffers can be toggled to display a
737longer description by typing RET (log-view-toggle-entry-display).
738In the Log View buffers made by `C-x v L' (vc-print-root-log), you can
739use this to display the full log entry for the revision at point.
740
33f6cf7b 741**** Currently supported for Bzr, Git, and Mercurial.
d4eb88c7
CY
742
743**** Packages using Log View mode can enable this functionality by
744binding `log-view-expanded-log-entry-function' to a suitable function.
745
1c6c854e
CS
746*** New command `vc-ediff' allows visual comparison of two revisions
747of a file similar to `vc-diff', but using ediff backend.
748
0fe719e6
GM
749** Miscellaneous
750
751---
752*** `copyright-fix-years' can optionally convert consecutive years to ranges.
753
5b3e6db8
GM
754*** New command `nato-region' converts text to NATO phonetic alphabet.
755
0f0c1f27
EZ
756*** The new command `info-display-manual' will display an Info manual
757specified by its name. If that manual is already visited in some Info
758buffer within the current session, the command will display that
759buffer. Otherwise, it will load the manual and display it. This is
760handy if you have many manuals in many Info buffers, and don't
761remember the name of the buffer visiting the manual you want to
762consult.
763
eb199145
GM
764\f
765* New Modes and Packages in Emacs 24.1
d445b3f8 766
60e56523
LL
767** Occur Edit mode applies edits made in *Occur* buffers to the
768original buffers. It is bound to C-x C-q in Occur mode.
769
7100ff98
SM
770** New global minor modes electric-pair-mode, electric-indent-mode,
771and electric-layout-mode.
3b843809 772
a83ec3c9
CY
773** tabulated-list.el provides a generic major mode for tabulated data,
774from which other modes can be derived.
775
d02c9bcd
SM
776** pcase.el provides the ML-style pattern matching macro `pcase'.
777
7725ebb7
MA
778** secrets.el is an implementation of the Secret Service API, an
779interface to password managers like GNOME Keyring or KDE Wallet. The
065f2743
MA
780Secret Service API requires D-Bus for communication. The command
781`secrets-show-secrets' offers a buffer with a visualization of the
782secrets.
7725ebb7 783
f9e78150
MA
784** notifications.el provides an implementation of the Desktop
785Notifications API. It requires D-Bus for communication.
786
12fe5bcc
MA
787** soap-client.el supports access to SOAP web services from Emacs.
788soap-inspect.el is an interactive inspector for SOAP WSDL structures.
789
ad7d6ecb
GM
790** xmodmap-generic-mode for xmodmap files.
791
eb199145
GM
792\f
793* Incompatible Lisp Changes in Emacs 24.1
6dfcbe31 794
fa6996bc
EZ
795---
796** `char-direction-table' and the associated function `char-direction'
797were deleted. They were buggy and inferior to the new support of
798bidirectional editing introduced in Emacs 24. If you need the
799bidirectional properties of a character, use `get-char-code-property'
800with the last argument `bidi-class'.
801
470d996d
TV
802** `copy-directory' now copies the source directory as a subdirectory
803of the target directory, if the latter is an existing directory. The
804new optional arg COPY-CONTENTS, if non-nil, makes the function copy
805the contents directly into a pre-existing target directory.
806
25ca2e61
CY
807** `compose-mail' now accepts an optional 8th arg, RETURN-ACTION, and
808passes it to the mail user agent function. This argument specifies an
809action for returning to the caller after finishing with the mail.
810This is currently used by Rmail to delete a mail window.
811
9173a8fb
CY
812** For mouse click input events in the text area, the Y pixel
813coordinate in the POSITION list now counts from the top of the text
814area, excluding any header line. Previously, it counted from the top
815of the header line.
816
c4d17d50
SM
817** Remove obsolete name `e' (use `float-e' instead).
818
288cf4e9
SM
819** A backquote not followed by a space is now always treated as new-style.
820
fd5c9dfa 821** Test for special mode-class was moved from view-file to view-buffer.
288cf4e9
SM
822FIXME: This only says what was changed, but not what are the
823programmer-visible consequences.
fd5c9dfa 824
3b7e1d5f 825** Passing a nil argument to a minor mode function now turns the mode
0a19a6f8 826ON unconditionally.
6431f2e6
CY
827
828** During startup, Emacs no longer adds entries for `menu-bar-lines'
0a19a6f8
JB
829and `tool-bar-lines' to `default-frame-alist' and `initial-frame-alist'.
830With these alist entries omitted, `make-frame' checks the value of the
831variable `menu-bar-mode'/`tool-bar-mode' to determine whether to create
832a menu-bar or tool-bar, respectively. If the alist entries are added,
833they override the value of `menu-bar-mode'/`tool-bar-mode'.
6431f2e6 834
fe0aa820
CY
835** Regions created by mouse dragging are now normal active regions,
836similar to the ones created by shift-selection. In previous Emacs
837versions, these regions were delineated by `mouse-drag-overlay', which
838has now been removed.
d6d8ee7a 839
4583e796
GM
840** cl.el no longer provides `cl-19'.
841
3226d6ca
GM
842** The following functions and aliases, obsolete since at least Emacs 21.1,
843have been removed:
844comint-kill-output, decompose-composite-char, outline-visible,
845internal-find-face, internal-get-face, frame-update-faces,
846frame-update-face-colors, x-frob-font-weight, x-frob-font-slant,
847x-make-font-bold, x-make-font-demibold, x-make-font-unbold
848x-make-font-italic, x-make-font-oblique, x-make-font-unitalic
849x-make-font-bold-italic, mldrag-drag-mode-line, mldrag-drag-vertical-line,
922ad43e
GM
850iswitchb-default-keybindings, char-bytes, isearch-return-char,
851make-local-hook
3226d6ca
GM
852
853** The following variables and aliases, obsolete since at least Emacs 21.1,
854have been removed:
6aecca99
GM
855checkdoc-minor-keymap, vc-header-alist, directory-sep-char,
856font-lock-defaults-alist
3226d6ca 857
7b0e3048
GM
858** The following files, obsolete since at least Emacs 21.1, have been removed:
859sc.el, x-menu.el, rnews.el, rnewspost.el
860
33658d4e
CY
861** FIXME finder-inf.el changes.
862
eb199145
GM
863\f
864* Lisp changes in Emacs 24.1
9097e8af 865
a2a25d24
SM
866** Completion
867*** New variable completion-extra-properties used to specify extra properties
868of the current completion:
869- :annotate-function, same as the old completion-annotate-function.
870- :exit-function, function to call after completion took place.
871
872*** Functions on completion-at-point-functions can return any of the properties
873valid for completion-extra-properties.
874
875*** completion-annotate-function is obsolete.
876
620c53a6
SM
877*** New `metadata' method for completion tables. The metadata thus returned
878can specify various details of the data returned by `all-completions':
879- `category' is the kind of objects returned (e.g., `buffer', `file', ...),
880 used to select a style in completion-category-overrides.
881- `annotation-function' to add annotations in *Completions*.
882- `display-sort-function' to specify how to sort entries in *Completions*.
883- `cycle-sort-function' to specify how to sort entries when cycling.
884
f042970d 885** `glyphless-char-display' can now distinguish between graphical and
16a43933
CY
886text terminal display, via a char-table entry that is a cons cell.
887
da91b5f2
CY
888** `open-network-stream' can now be used to open an encrypted stream.
889It now accepts an optional `:type' parameter for initiating a TLS
890connection, directly or via STARTTLS. To do STARTTLS, additional
891parameters (`:end-of-command', `:success', `:capabilities-command')
892must also be supplied.
893
03408648
SM
894** Code can now use lexical scoping by default instead of dynamic scoping.
895The `lexical-binding' variable lets code use lexical scoping for local
896variables. It is typically set via file-local variables, in which case it
897applies to all the code in that file.
898
899*** `eval' takes a new optional argument `lexical' to choose the new lexical
900binding instead of the old dynamic binding mode.
901
902*** Lexically scoped interpreted functions are represented with a new form
903of function value which looks like (closure ENV ARGS &rest BODY).
904
905*** New macro `letrec' to define recursive local functions.
906
907*** New function `special-variable-p' to check whether a variable is
908declared as dynamically bound.
909
f6d62986
SM
910** pre/post-command-hook are not reset to nil upon error.
911Instead, the offending function is removed.
912
913** New low-level function run-hook-wrapped.
914
7deebf1b
LMI
915** `server-eval-at' is provided to allow evaluating forms on different
916Emacs server instances.
917
918** `call-process' allows a `(:file "file")' spec to redirect STDOUT to
919a file.
920
53cfe624 921** byte-compile-disable-print-circle is obsolete.
78f64af0 922** deferred-action-list and deferred-action-function are obsolete.
e7f7fbaa
SM
923** Removed the stack-trace-on-error variable.
924Also the debugger can now "continue" from an error, which means it will jump
925to the error handler as if the debugger had not been invoked instead of
926jumping all the way to the top-level.
927
3ef01959
CY
928** New function `read-char-choice' reads a restricted set of characters,
929discarding any inputs not inside the set.
930
2e288d54
JB
931** `image-library-alist' is renamed to `dynamic-library-alist'.
932The variable is now used to load all kind of supported dynamic libraries,
933not just image libraries. The previous name is still available as an
934obsolete alias.
935
cf38dd42
SM
936** New variable syntax-propertize-function to set syntax-table properties.
937Replaces font-lock-syntactic-keywords which are now obsolete.
938This allows syntax-table properties to be set independently from font-lock:
939just call syntax-propertize to make sure the text is propertized.
940Together with this new variable come a new hook
941syntax-propertize-extend-region-functions, as well as two helper functions:
942syntax-propertize-via-font-lock to reuse old font-lock-syntactic-keywords
943as-is; and syntax-propertize-rules which provides a new way to specify
944syntactic rules.
945
a2e5caf7
SM
946** New hook post-self-insert-hook run at the end of self-insert-command.
947
7cf78aac 948+++
c5683ceb 949** Syntax tables support a new "comment style c" additionally to style b.
4e2db1fe 950** frame-local variables cannot be let-bound any more.
10dcc561 951** prog-mode is a new major-mode meant to be the parent of programming mode.
f44379e7
SM
952** define-minor-mode accepts a new keyword :variable.
953
b2957ea8 954** `delete-file' and `delete-directory' now accept optional arg TRASH.
f1a5d776
CY
955Trashing is performed if TRASH and `delete-by-moving-to-trash' are
956both non-nil. Interactively, TRASH defaults to t, unless a prefix
957argument is supplied (see Trash changes, above).
53967e09 958
8f92b8ad
SM
959** buffer-substring-filters is obsoleted by filter-buffer-substring-functions.
960
9317e499
CY
961** `facemenu-read-color' is now an alias for `read-color'.
962The command `read-color' now requires a match for a color name or RGB
963triplet, instead of signalling an error if the user provides a invalid
964input.
965
4039c786
CY
966** Tool-bars can display separators.
967Tool-bar separators are handled like menu separators in menu-bar maps,
94975270 968i.e. via menu entries of the form `(menu-item "--")'.
9317e499 969
00fe2df1
JL
970** Image API
971
972*** When the image type is one of listed in `image-animated-types'
1546c559 973and the number of sub-images in the image is more than one, then the
00fe2df1
JL
974new function `create-animated-image' creates an animated image where
975sub-images are displayed successively with the duration defined by
976`image-animate-max-time' and the delay between sub-images defined
977by the Graphic Control Extension of the image.
978
1546c559
JL
979*** `image-extension-data' is renamed to `image-metadata'.
980
71c17aec
LMI
981** XML and HTML parsing
982
983*** If Emacs is compiled with libxml2 support (which is the default),
4b9832a6 984two new Emacs Lisp-level functions are defined:
84156e94
MA
985`libxml-parse-html-region' (which will parse "real world" HTML)
986and `libxml-parse-xml-region' (which parses XML). Both return an
4b9832a6
CY
987Emacs Lisp parse tree.
988
989FIXME: These should be front-ended by xml.el.
990
e2574f2c
TZ
991** GnuTLS
992
993*** Emacs can be compiled with libgnutls support
994This is the default. You will then be able to use the functionality
995in gnutls.el, namely the `open-gnutls-stream' and `gnutls-negotiate'
996functions. It's easiest to use these functions through
997`open-network-stream' because it can upgrade connections through
998STARTTLS opportunistically or use plain SSL, depending on your needs.
999
1000Only versions 2.8.x and higher or GnuTLS have been tested.
1001
1002*** gnutls-log-level
1003Set `gnutls-log-level' higher than 0 to get debug output. 1 is for
1004important messages, 2 is for debug data, and higher numbers are as per
1005the GnuTLS logging conventions. The output is in *Messages*.
71c17aec 1006
a6020335
MH
1007** Isearch
1008
1009*** New hook `isearch-update-post-hook' that runs in `isearch-update'.
1010
9326ba26
CY
1011** Progress reporters can now "spin".
1012The MIN-VALUE and MAX-VALUE arguments of `make-progress-reporter' can
1013now be nil, or omitted. This makes a "non-numeric" reporter. Each
1014time you call `progress-reporter-update' on that progress reporter,
1015with a nil or omitted VALUE argument, the reporter message is
1016displayed with a "spinning bar".
1017
3e214b50
JB
1018** New variable `revert-buffer-in-progress-p' is true while a buffer is
1019being reverted, even if the buffer has a local `revert-buffer-function'.
1020
638f053a
JB
1021** New variables `delayed-warnings-list' and `delayed-warnings-hook' allow
1022deferring warnings until the main command loop is executed.
1023
e145f188
GM
1024+++
1025** `set-auto-mode' now respects mode: local variables at the end of files,
1026as well as those in the -*- line.
1027
eb199145
GM
1028\f
1029* Changes in Emacs 24.1 on non-free operating systems
d53a60a6 1030
0a19a6f8 1031** New configure.bat option --enable-checking builds Emacs with extra
04779484
JB
1032runtime checks.
1033
e3aef5c6 1034** New configure.bat option --distfiles to specify files to be
0a19a6f8 1035included in binary distribution.
e3aef5c6 1036
e2574f2c
TZ
1037** New configure.bat option --without-gnutls to disable automatic
1038GnuTLS detection.
1039
1040** New configure.bat option --lib for general library linkage, works
1041with the USER_LIBS build variable.
1042
0a19a6f8 1043** New make target `dist' to create binary distribution for MS Windows.
e3aef5c6 1044
05197f40 1045\f
a933dad1 1046----------------------------------------------------------------------
5b87ad55 1047This file is part of GNU Emacs.
a933dad1 1048
ab73e885 1049GNU Emacs is free software: you can redistribute it and/or modify
5b87ad55 1050it under the terms of the GNU General Public License as published by
ab73e885
GM
1051the Free Software Foundation, either version 3 of the License, or
1052(at your option) any later version.
5b87ad55
GM
1053
1054GNU Emacs is distributed in the hope that it will be useful,
1055but WITHOUT ANY WARRANTY; without even the implied warranty of
1056MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1057GNU General Public License for more details.
a933dad1 1058
5b87ad55 1059You should have received a copy of the GNU General Public License
ab73e885 1060along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
a933dad1 1061
05197f40 1062\f
a933dad1
DL
1063Local variables:
1064mode: outline
1065paragraph-separate: "[ \f]*$"
1066end: