New function read-char-choice for reading a restricted set of chars.
[bpt/emacs.git] / etc / NEWS
CommitLineData
29b7722a 1GNU Emacs NEWS -- history of user-visible changes.
5b87ad55 2
d5612228 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
EZ
50---
51** New translation of the Emacs Tutorial in Hebrew is available
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
0bfd685e 65\f
eb199145 66* Changes in Emacs 24.1
7841339b 67
2a847524
CY
68** emacsclient changes
69
70*** New emacsclient argument --parent-id ID can be used to open a
0191e222
CY
71client frame in parent X window ID, via XEmbed. This works like the
72--parent-id argument to Emacs.
73
2a847524
CY
74*** If emacsclient shuts down as a result of Emacs signalling an
75error, its exit status is 1.
76
902a6d8d
SM
77** Completion can cycle, depending on completion-cycle-threshold.
78
2372f278
SM
79** auto-mode-case-fold is now enabled by default.
80
f4b6ba46
EZ
81+++
82** Emacs now supports display and editing of bidirectional text.
f4b6ba46
EZ
83
84See the node "Bidirectional Editing" in the Emacs Manual for some
85initial documentation.
86
87To turn this on in any given buffer, set the buffer-local variable
88`bidi-display-reordering' to a non-nil value. The default is nil.
89
90The buffer-local variable `bidi-paragraph-direction', if non-nil,
91forces each paragraph in the buffer to have its base direction
92according to the value of this variable. Possible values are
93`right-to-left' and `left-to-right'. If the value is nil (the
94default), Emacs determines the base direction of each paragraph from
95its text, as specified by the Unicode Bidirectional Algorithm.
96
d20e1419
EZ
97The function `current-bidi-paragraph-direction' returns the actual
98value of paragraph base direction at point.
99
f4b6ba46
EZ
100Reordering of bidirectional text for display in Emacs is a "Full
101bidirectionality" class implementation of the Unicode Bidirectional
102Algorithm.
103
46759717
EZ
104Note that some advanced display features, such as overlay strings and
105`display' text properties, do not yet work correctly when
106bidirectional text is reordered for display.
107
303500aa 108** GTK scroll-bars are now placed on the right by default.
52834b6b
CY
109Use `set-scroll-bar-mode' to change this.
110
20fe03ad 111** GTK tool bars can have just text, just images or images and text.
d8004abe 112Customize `tool-bar-style' to choose style. On a Gnome desktop, the default
20fe03ad
JD
113is taken from the desktop settings.
114
8b2dd508
JD
115** GTK tool bars can be placed on the left/right or top/bottom of the frame.
116The frame-parameter tool-bar-position controls this. It takes the values
1c0d77cc 117top, left, right or bottom. The Options => Show/Hide menu has entries
8b2dd508
JD
118for this.
119
8740c12d 120** ImageMagick support.
b2fa3a09
GM
121It is now possible to use the ImageMagick library to load many new
122image formats in Emacs. By default, Emacs links with the ImageMagick
123libraries if they are present at build time. To disable this, use
8ea189f7 124the configure option `--without-imagemagick'.
16a91140 125
8740c12d
GM
126The new function `imagemagick-types' returns a list of image file
127extensions that your installation of ImageMagick supports. The
128function `imagemagick-register-types' enables ImageMagick support for
b2957ea8 129these image types, minus those listed in `imagemagick-types-inhibit'.
16a91140 130
8740c12d 131See the Emacs Lisp Reference Manual for more information.
16a91140 132
3a46642b
J
133** The colors for selected text (the region face) are taken from the GTK
134theme when Emacs is built with GTK.
135
aa1859f5
J
136** Emacs uses GTK tooltips by default if built with GTK. You can turn that
137off by customizing x-gtk-use-system-tooltips.
138
1ecb2d3f 139** Lucid menus and dialogs can display antialiased fonts if Emacs is built
a6ac7fc4
JD
140with Xft. To change font, use X resource faceName, for example:
141Emacs.pane.menubar.faceName: Courier-12
142Set faceName to none and use font to use the old X fonts.
99852628 143
0eb025fb
EZ
144+++
145** Enhanced support for characters that have no glyphs in available fonts
146If a character has no glyphs in any of the available fonts, Emacs by
147default will display it either as a hexadecimal code in a box or as a
148thin 1-pixel space. In addition to these two methods, Emacs can
149display these characters as empty box, as an acronym, or not display
150them at all. To change how these characters are displayed, customize
151the variable `glyphless-char-display-control'.
152
153On character terminals these methods are used for characters that
154cannot be encoded by the `terminal-coding-system'.
155
917794d5
CY
156** On graphical displays, the mode-line no longer ends in dashes.
157
b7d65a5f
GM
158** Basic SELinux support has been added.
159This requires Emacs to be linked with libselinux at build time.
160
d8004abe
GM
161*** Emacs preserves the SELinux file context when backing up, and
162optionally when copying files. To this end, copy-file has an extra
163optional argument, and backup-buffer and friends include the SELinux
164context in their return values.
b7d65a5f
GM
165
166*** The new functions file-selinux-context and set-file-selinux-context
167get and set the SELinux context of a file.
168
a5bee597
MA
169*** Tramp offers handlers for file-selinux-context and set-file-selinux-context
170for remote machines which support SELinux.
171
9c524fcb 172** The function kill-emacs is now run upon receipt of the signals SIGTERM
383ebd15 173and SIGHUP, and upon SIGINT in batch mode.
9c524fcb
GM
174
175** kill-emacs-hook is now also run in batch mode.
176
79ce172a 177** New scrolling commands `scroll-up-command' and `scroll-down-command'
7b05466f
JL
178(bound to C-v/[next] and M-v/[prior]) does not signal errors at top/bottom
179of buffer at first key-press (instead moves to top/bottom of buffer)
180when a new variable `scroll-error-top-bottom' is non-nil.
79ce172a 181
5a97d2da
JL
182** New scrolling commands `scroll-up-line' and `scroll-down-line'
183scroll a line instead of full screen.
184
a4b000fb 185** New property `scroll-command' should be set on a command's symbol to
b2957ea8 186define it as a scroll command affected by `scroll-preserve-screen-position'.
9013a7f8 187
f1a5d776
CY
188** Trash changes
189
190*** `delete-by-moving-to-trash' now only affects commands that specify
191trashing. This avoids inadvertently trashing temporary files.
192
193*** Calling `delete-file' or `delete-directory' with a prefix argument
194now forces true deletion, regardless of `delete-by-moving-to-trash'.
195
f0bf7c8e
JL
196** New option `list-colors-sort' defines the color sort order
197for `list-colors-display'.
198
44198b6e
CY
199** An Emacs Lisp package manager is now included.
200This is a convenient way to download and install additional packages,
42d9cffa 201from a package repository at elpa.gnu.org.
cb6c4991
CY
202
203*** `M-x list-packages' shows a list of packages, which can be
204selected for installation.
205
206*** New command `describe-package', bound to `C-h P'.
44198b6e
CY
207
208*** By default, all installed packages are loaded and activated
209automatically when Emacs starts up. To disable this, set
210`package-enable-at-startup' to nil. To change which packages are
211loaded, customize `package-load-list'.
212
f065864f
CY
213** Custom Themes
214
215*** `M-x customize-themes' lists Custom themes which can be enabled.
216
782b5e8d
CY
217*** New option `custom-theme-load-path' is the load path for themes.
218Emacs no longer looks for custom themes in `load-path'. The default
219is to search in `custom-theme-directory', followed by a built-in theme
220directory named "themes/" in `data-directory'.
221
4ddf410a
MA
222** The user option `remote-file-name-inhibit-cache' controls whether
223the remote file-name cache is used for read access.
224
17284e30
GM
225** The standalone programs lib-src/digest-doc and sorted-doc have been
226replaced with Lisp commands `doc-file-to-man' and `doc-file-to-info'.
227
f13183cf
CY
228** The variable `focus-follows-mouse' now always defaults to nil.
229
0bfd685e 230\f
eb199145 231* Editing Changes in Emacs 24.1
b350bdf2 232
ea4f7750
GM
233+++
234** There is a new command `count-words-region', which does what you expect.
235
67027b49 236** completion-at-point now handles tags and semantic completion.
a982c7ec 237
d74cba8f
MA
238** The default value of `backup-by-copying-when-mismatch' is now t.
239
1c708c1a
CY
240** The command `just-one-space' (C-SPC), if given a negative argument,
241also deletes newlines around point.
242
b9229673
CY
243** Deletion changes
244
245*** New option `delete-active-region'.
246If non-nil, C-d, [delete], and DEL delete the region if it is active
247and no prefix argument is given. If set to `kill', these commands
248kill instead.
249
250*** New command `delete-forward-char', bound to C-d and [delete].
42d9cffa
CY
251This is meant for interactive use, and obeys `delete-active-region'.
252The command `delete-char' does not obey `delete-active-region'.
b9229673
CY
253
254*** `delete-backward-char' is now a Lisp function.
255Apart from obeying `delete-active-region', its behavior is unchanged.
256However, the byte compiler now warns if it is called from Lisp; you
257should use delete-char with a negative argument instead.
258
259*** The option `mouse-region-delete-keys' has been deleted.
260
f9d71b42
CY
261** Selection changes.
262
7c23dd44 263The default handling of clipboard and primary selections has been
42d9cffa
CY
264changed to conform with other X applications. The exact changes are
265described below; in short, mouse commands to select and paste text now
266use the primary selection, while all other commands for killing and
267yanking text now use the clipboard.
7c23dd44 268
42d9cffa
CY
269*** Merely selecting text (e.g. with drag-mouse-1) does not add it to
270the kill-ring. On systems with a primary selection separate from the
271clipboard (such as X), the selected text is put in the primary
272selection.
273
274*** mouse-2 is now bound to `mouse-yank-primary', which pastes from
275the primary selection regardless of the contents of the kill-ring.
276
277*** Commands that kill text or copy it to the kill-ring (M-w, C-w,
278C-k, etc.) also put the killed text into the clipboard. This change
279also means that the "Copy", "Cut", and "Paste" items in the "Edit"
280menu are now exactly equivalent to, respectively M-w, C-w, and C-y.
281
282*** Yank commands, such as C-y and M-y, retrieve text from the
283clipboard if it is available.
284
285*** The above changes are reflected in the following new defaults:
286
287**** `select-active-regions' now defaults to t.
d1b08c88 288It also accepts a new value, `only', which means to only set the
7c23dd44
CY
289primary selection for temporarily active regions (usually made by
290mouse-dragging or shift-selection).
291
42d9cffa 292**** `mouse-2' is now bound to `mouse-yank-primary'.
7c9b11be 293Previously, it was bound to `mouse-yank-at-click' (which is now
4c0f50c9 294unbound by default).
f9d71b42 295
42d9cffa
CY
296**** `x-select-enable-clipboard' now defaults to t on all platforms.
297Note that this variable was already non-nil by default on MS-Windows,
298which does not support the primary selection between applications.
f9d71b42 299
42d9cffa 300**** `x-select-enable-primary' now defaults to nil.
7c9b11be
EZ
301This variable exists only on X; its default value was t in previous
302versions.
2490cbbc 303
42d9cffa
CY
304**** `mouse-drag-copy-region' now defaults to nil.
305
306*** To return to the previous behavior, where mouse commands use the
307clipboard, change `mouse-drag-copy-region' and (on X only)
308`x-select-enable-primary' to t. If you don't want Emacs to put the
309text into the clipboard, only to the primary selection, additionally
310set `x-select-enable-clipboard' to nil.
f9d71b42 311
084e6df3
JD
312*** Support for X cut buffers has been removed.
313
99f053cf
JA
314** New command `rectangle-number-lines', bound to `C-x r N', numbers
315the lines in the current rectangle. With an prefix argument, this
316prompts for a number to count from and for a format string.
317
9bae34bf 318\f
eb199145 319* Changes in Specialized Modes and Packages in Emacs 24.1
efeb796b 320
78835dd0
SM
321** shell-mode can track your cwd by reading it from your prompt.
322Just set shell-dir-cookie-re to an appropriate regexp.
323
cbf83ce9
SM
324** Modula-2 mode provides auto-indentation.
325
b879a6e2
SM
326** latex-electric-env-pair-mode keeps \begin..\end matched on the fly.
327
360ac530 328** FIXME: xdg-open for browse-url and reportbug, 2010/08.
0ac3effe 329
b3671a51
JL
330** Archive Mode has basic support to browse 7z archives.
331
876d1684
LMI
332** browse-url has gotten a new variable that is used for mailto: URLs,
333 `browse-url-mailto-function', which defaults to `browse-url-mail'.
334
8a8d54cd
VD
335** ERC changes
336
337*** New vars `erc-autojoin-timing' and `erc-autojoin-delay'.
338If the value of `erc-autojoin-timing' is 'ident, ERC autojoins after a
339successful NickServ identification, or after `erc-autojoin-delay'
340seconds. The default value, 'ident, means to autojoin immediately
341after connecting.
342
5c0c0f77
LMI
343*** New variable `erc-coding-system-precedence': If we use `undecided'
344as the server coding system, this variable will then be consulted.
345The default is to decode strings that can be decoded as utf-8 as
346utf-8, and do the normal `undecided' decoding for the rest.
347
c0e505e5
CY
348** Eshell changes
349
350*** The default value of eshell-directory-name is a directory named
351"eshell" in `user-emacs-directory'. If the old "~/.eshell/" directory
352exists, that is used instead.
353
27d3cd56
CY
354** In ido-mode, C-v is no longer bound to ido-toggle-vc.
355The reason is that this interferes with cua-mode.
356
c1e25821 357** partial-completion-mode is now obsolete.
79ccd68f
SM
358You can get a comparable behavior with:
359(setq completion-styles '(partial-completion initials))
360(setq completion-pcm-complete-word-inserts-delimiters t)
c1e25821 361
18c812bd 362** mpc.el: Can use pseudo tags of the form tag1|tag2 as a union of two tags.
b2957ea8 363
1d83b0e9
GM
364** server can listen on a specific port using the server-port option.
365
cf16af42
GM
366** Calendar, Diary, and Appt
367
368---
369*** The obsolete (since Emacs 22.1) method of enabling the appt package
370by adding appt-make-list to diary-hook has been removed. Use appt-activate.
371
372---
373*** Some appt variables (obsolete since Emacs 22.1) have been removed:
374appt-issue-message (use the function appt-activate)
375appt-visible/appt-msg-window (use the variable appt-display-format)
376
377---
378*** Some diary function aliases (obsolete since Emacs 22.1) have been removed:
379view-diary-entries, list-diary-entries, show-all-diary-entries
380
52834b6b
CY
381** Customize
382
383*** Customize buffers now contain a search field.
384The search is performed using `customize-apropos'.
42d9cffa 385To turn off the search field, set custom-search-field to nil.
52834b6b
CY
386
387*** Custom options now start out hidden if at their default values.
388Use the arrow to the left of the option name to toggle visibility.
389
390*** custom-buffer-sort-alphabetically now defaults to t.
391
392*** The color widget now has a "Choose" button, which allows you to
393choose a color via list-colors-display.
394
f5d6548a
JL
395** Dired-x
396
397*** dired-jump and dired-jump-other-window called with a prefix argument
398read a file name from the minibuffer instead of using buffer-file-name.
399
8117868f
DN
400** Directory local variables can apply to file-less buffers.
401For example, adding "(diff-mode . ((mode . whitespace)))" to your
d8004abe 402.dir-locals.el file, will turn on `whitespace-mode' for *vc-diff* buffers.
8117868f 403
7492acc9
MM
404** SQL Mode enhancements.
405
30c4d8dc
MM
406*** Several variables have been marked as safe local variables. The
407variables `sql-product', `sql-user', `sql-server', `sql-database' and
408`sql-port' can now be safely used as local variables.
7492acc9 409
9250002f
MM
410*** `sql-dialect' is a synonym for `sql-product'.
411
74790210 412*** Added ability to login with a port on MySQL and Postgres.
7492acc9 413The custom variable `sql-port' can be specified for connection to
74790210
MM
414MySQL or Postgres servers. By default, the port is not listed in
415either login parameter, but will be added to the command line if set
416to a non-zero value.
7492acc9 417
9250002f
MM
418*** Dynamic selection of product in an SQL interactive session.
419If you use `sql-product-interactive' to start an SQL interactive
420session it uses the current value of `sql-product'. Preceding the
421invocation with C-u will force it to ask for the product before
422creating the session.
423
424*** Renaming a SQL interactive buffer when it is created.
425Prefixing the SQL interactive commands (`sql-sqlite', `sql-postgres',
426`sql-mysql', etc.) with C-u will force a new interactive session to be
427started and will prompt for the new name. This will reduce the need
428for `sql-rename-buffer' is most common use cases.
429
3bd2cfef
MM
430*** Command continuation prompts in SQL interactive mode are suppressed.
431Multiple line commands in SQL interactive mode, generate command
432continuation prompts which needlessly confuse the output. These
433prompts are now filtered out from the output. This change impacts
434multiple line SQL statements entered with C-j between each line,
435statements yanked into the buffer and statements sent with
436`sql-send-*' functions.
437
7492acc9
MM
438*** Custom variables control prompting for login parameters.
439Each supported product has a custom variable `sql-*-login-params'
440which is a list of the parameters to be prompted for before a
441connection is established.
442
74790210
MM
443The lists consist of the following five tokens: `user', `password',
444`database', `server', and `port'. The order in which they appear is
445the order in which they are prompted. The tokens symbols can be
446replaced by a sublist starting with the token and followed by a plist
447which control the prompting for values. The tokens `user',
448`database', and `server' each can take a property of :default which
449specifies the value to be used if no value is entered. The
450`database', `server', and `port' tokens handle the :completion
451property which restricts the entry to either one of the values in the
452list or to one of the values returned by the function provided as the
453property value. The `database' and `server' tokens also accept the
454:file property whose value is a regexp to identify useful file names.
455
456 (user :default DEF)
457 (database :default DEF
458 :file FILEPAT
459 :completion COMPLETE)
460 (server :default DEF
461 :file FILEPAT
462 :completion COMPLETE)
463
464The FILEPAT when :file is specified is a regexp that will match valid
465file names (without the directory portion). Generally these strings
466will be of the form ".+\.SUF" where SUF is the desired file suffix.
467
468When :completion is specified, the COMPLETE corresponds to the
469PREDICATE argument to the `completing-read' function (a list of
470possible values or a function returning such a list).
5474c40f 471
30c4d8dc
MM
472*** Added `sql-connection-alist' to record login parameter values.
473An alist for recording different username, database and server
474values. If there are multiple databases that you connect to the
475parameters needed can be stored in this alist.
476
477For example, the following might be set in the user's init.el:
478
479 (setq sql-connection-alist
480 '((dev (sql-product 'sqlite)
481 (sql-database "/home/mmaug/dev.db"))
482 (prd (sql-product 'oracle)
483 (sql-user "mmaug")
484 (sql-database "iprd2a"))))
485
486This defines two connections named "dev" and "prd".
487
488*** Added `sql-connect' to use predefined connections.
489Sets the login parameters based on the values in the
490`sql-connection-alist' and start a SQL interactive session. Any
491values specified in the connection will not be prompted for.
492
493In the example above, if the user were to invoke M-x sql-connect, they
494would be prompted for the connection. The user can respond with
495either "dev" or "prd". The "dev" connection would connect to the
496SQLite database without prompting; the "prd" connection would prompt
497for the users password and then connect to the Oracle database.
498
d26b0ea9 499**** Added SQL->Start... submenu when connections are defined.
b2957ea8 500When connections have been defined, there is a submenu available that
d26b0ea9
MM
501allows the user to select one to start a SQLi session. The "Start
502SQLi Session" item moves to the "Start..." submenu when cnnections
503have been defined.
504
505**** Added "Save Connection" menu item in SQLi buffers.
506When a SQLi session is not started by a connection then
507`sql-save-connection' will gather the login params specified for the
508session and save them as a new connection.
509
74790210
MM
510*** List database objects and details.
511Once a SQL interactive session has been started, you can get a list of
512the objects in the database and see details of those objects. The
513objects shown and the details available are product specific.
514
515**** List all objects.
516Using `M-x sql-list-all', `C-c C-l a' or selecting "SQL->List all
517objects" will list all the objects in the database. At a minimum it
518lists the tables and views in the database. Preceeding the command by
519universal argument may provide additional details or extend the
520listing to include other schemas objects. The list will appear in a
521separate window in view-mode.
522
523**** List Table details.
524Using `M-x sql-list-table', `C-c C-l t' or selecting "SQL->List Table
525details" will ask for the name of a database table or view and display
526the list of columns in the relation. Preceeding the comand with the
527universal argument may provide additional details about each column.
528The list will appear in a separate window in view-mode.
529
7492acc9
MM
530*** Added option `sql-send-terminator'.
531When set makes sure that each command sent with `sql-send-*' commands
532are properly terminated and submitted to the SQL processor.
533
534*** Added option `sql-oracle-scan-on'.
535When set commands sent to Oracle's SQL*Plus are scanned for strings
30c4d8dc
MM
536starting with an ampersand and the user is asked for replacement text.
537In general, the SQL*Plus option SCAN should always be set OFF under
538SQL interactive mode and this option used in its place.
7492acc9
MM
539
540*** SQL interactive mode will replace tabs with spaces.
541This prevents the comand interpretter for MySQL and Postgres from
542listing object name completions when being sent text via
543`sql-send-*' functions.
544
545*** An API for manipulating SQL product definitions has been added.
546
723ee192
SM
547** sregex.el is now obsolete, since rx.el is a strict superset.
548
5e418f17
JL
549** s-region.el is now declared obsolete, superceded by shift-select-mode
550enabled by default in 23.1.
551
691cf4a0
NR
552** gdb-mi
553
554*** GDB User Interface migrated to GDB Machine Interface and now
555supports multithread non-stop debugging and debugging of several
556threads simultaneously.
557
37221432
MA
558** D-Bus
559
560*** It is possible now, to access alternative buses than the default
561system or session bus.
562
412b9ee5
MA
563*** dbus-register-{method,property} do not necessarily register names anymore.
564
459bba37
MA
565** Tramp
566
a808d31f
MA
567*** There exists a new inline access method "ksu" (kerberized su).
568
459bba37
MA
569*** The following access methods are discontinued: "ssh1_old",
570"ssh2_old", "scp1_old", "scp2_old" and "fish".
571
0c32ce32
CY
572** VC and related modes
573
574*** Support for pulling on distributed version control systems.
575The vc-update command now runs a "pull" operation, if it is supported.
576This updates the current branch from upstream. A prefix argument
577means to prompt the user for command specifics, e.g. a pull location.
578
579**** vc-pull is an alias for vc-update.
580
581**** Currently supported by Bzr.
582
583*** Support for merging on distributed version control systems.
584The vc-merge command now runs a "merge" operation, if it is supported.
585This merges another branch into the current one. A prefix argument
586means to prompt the user for command specifics, e.g. a merge location.
587
588**** Currently supported by Bzr.
589
eb199145
GM
590\f
591* New Modes and Packages in Emacs 24.1
d445b3f8 592
7100ff98
SM
593** New global minor modes electric-pair-mode, electric-indent-mode,
594and electric-layout-mode.
3b843809 595
d02c9bcd
SM
596** pcase.el provides the ML-style pattern matching macro `pcase'.
597
7725ebb7
MA
598** secrets.el is an implementation of the Secret Service API, an
599interface to password managers like GNOME Keyring or KDE Wallet. The
065f2743
MA
600Secret Service API requires D-Bus for communication. The command
601`secrets-show-secrets' offers a buffer with a visualization of the
602secrets.
7725ebb7 603
f9e78150
MA
604** notifications.el provides an implementation of the Desktop
605Notifications API. It requires D-Bus for communication.
606
eb199145
GM
607\f
608* Incompatible Lisp Changes in Emacs 24.1
6dfcbe31 609
9173a8fb
CY
610** For mouse click input events in the text area, the Y pixel
611coordinate in the POSITION list now counts from the top of the text
612area, excluding any header line. Previously, it counted from the top
613of the header line.
614
c4d17d50
SM
615** Remove obsolete name `e' (use `float-e' instead).
616
288cf4e9
SM
617** A backquote not followed by a space is now always treated as new-style.
618
fd5c9dfa 619** Test for special mode-class was moved from view-file to view-buffer.
288cf4e9
SM
620FIXME: This only says what was changed, but not what are the
621programmer-visible consequences.
fd5c9dfa 622
3b7e1d5f
SM
623** Passing a nil argument to a minor mode function now turns the mode
624 ON unconditionally.
6431f2e6
CY
625
626** During startup, Emacs no longer adds entries for `menu-bar-lines'
627and `tool-bar-lines' to `default-frame-alist' and
628`initial-frame-alist'. With these alist entries omitted, `make-frame'
629checks the value of the variable `menu-bar-mode'/`tool-bar-mode' to
630determine whether to create a menu-bar or tool-bar, respectively.
631If the alist entries are added, they override the value of
632`menu-bar-mode'/`tool-bar-mode'.
633
fe0aa820
CY
634** Regions created by mouse dragging are now normal active regions,
635similar to the ones created by shift-selection. In previous Emacs
636versions, these regions were delineated by `mouse-drag-overlay', which
637has now been removed.
d6d8ee7a 638
4583e796
GM
639** cl.el no longer provides `cl-19'.
640
3226d6ca
GM
641** The following functions and aliases, obsolete since at least Emacs 21.1,
642have been removed:
643comint-kill-output, decompose-composite-char, outline-visible,
644internal-find-face, internal-get-face, frame-update-faces,
645frame-update-face-colors, x-frob-font-weight, x-frob-font-slant,
646x-make-font-bold, x-make-font-demibold, x-make-font-unbold
647x-make-font-italic, x-make-font-oblique, x-make-font-unitalic
648x-make-font-bold-italic, mldrag-drag-mode-line, mldrag-drag-vertical-line,
922ad43e
GM
649iswitchb-default-keybindings, char-bytes, isearch-return-char,
650make-local-hook
3226d6ca
GM
651
652** The following variables and aliases, obsolete since at least Emacs 21.1,
653have been removed:
6aecca99
GM
654checkdoc-minor-keymap, vc-header-alist, directory-sep-char,
655font-lock-defaults-alist
3226d6ca 656
7b0e3048
GM
657** The following files, obsolete since at least Emacs 21.1, have been removed:
658sc.el, x-menu.el, rnews.el, rnewspost.el
659
33658d4e
CY
660** FIXME finder-inf.el changes.
661
eb199145
GM
662\f
663* Lisp changes in Emacs 24.1
9097e8af 664
3ef01959
CY
665** New function `read-char-choice' reads a restricted set of characters,
666discarding any inputs not inside the set.
667
8c51d2a2
CY
668** `y-or-n-p' and `yes-or-no-p' now accept format string arguments.
669
2e288d54
JB
670** `image-library-alist' is renamed to `dynamic-library-alist'.
671The variable is now used to load all kind of supported dynamic libraries,
672not just image libraries. The previous name is still available as an
673obsolete alias.
674
cf38dd42
SM
675** New variable syntax-propertize-function to set syntax-table properties.
676Replaces font-lock-syntactic-keywords which are now obsolete.
677This allows syntax-table properties to be set independently from font-lock:
678just call syntax-propertize to make sure the text is propertized.
679Together with this new variable come a new hook
680syntax-propertize-extend-region-functions, as well as two helper functions:
681syntax-propertize-via-font-lock to reuse old font-lock-syntactic-keywords
682as-is; and syntax-propertize-rules which provides a new way to specify
683syntactic rules.
684
a2e5caf7
SM
685** New hook post-self-insert-hook run at the end of self-insert-command.
686
7cf78aac 687+++
c5683ceb 688** Syntax tables support a new "comment style c" additionally to style b.
4e2db1fe 689** frame-local variables cannot be let-bound any more.
10dcc561 690** prog-mode is a new major-mode meant to be the parent of programming mode.
f44379e7
SM
691** define-minor-mode accepts a new keyword :variable.
692
b2957ea8 693** `delete-file' and `delete-directory' now accept optional arg TRASH.
f1a5d776
CY
694Trashing is performed if TRASH and `delete-by-moving-to-trash' are
695both non-nil. Interactively, TRASH defaults to t, unless a prefix
696argument is supplied (see Trash changes, above).
53967e09 697
8f92b8ad
SM
698** buffer-substring-filters is obsoleted by filter-buffer-substring-functions.
699
00278747
SM
700** New completion style `substring'.
701
9317e499
CY
702** `facemenu-read-color' is now an alias for `read-color'.
703The command `read-color' now requires a match for a color name or RGB
704triplet, instead of signalling an error if the user provides a invalid
705input.
706
4039c786
CY
707** Tool-bars can display separators.
708Tool-bar separators are handled like menu separators in menu-bar maps,
94975270 709i.e. via menu entries of the form `(menu-item "--")'.
9317e499 710
00fe2df1
JL
711** Image API
712
713*** When the image type is one of listed in `image-animated-types'
1546c559 714and the number of sub-images in the image is more than one, then the
00fe2df1
JL
715new function `create-animated-image' creates an animated image where
716sub-images are displayed successively with the duration defined by
717`image-animate-max-time' and the delay between sub-images defined
718by the Graphic Control Extension of the image.
719
1546c559
JL
720*** `image-extension-data' is renamed to `image-metadata'.
721
71c17aec
LMI
722** XML and HTML parsing
723
724*** If Emacs is compiled with libxml2 support (which is the default),
4b9832a6 725two new Emacs Lisp-level functions are defined:
84156e94
MA
726`libxml-parse-html-region' (which will parse "real world" HTML)
727and `libxml-parse-xml-region' (which parses XML). Both return an
4b9832a6
CY
728Emacs Lisp parse tree.
729
730FIXME: These should be front-ended by xml.el.
731
cf16af42 732** FIXME GnuTLS
71c17aec 733
a6020335
MH
734** Isearch
735
736*** New hook `isearch-update-post-hook' that runs in `isearch-update'.
737
9326ba26
CY
738** Progress reporters can now "spin".
739The MIN-VALUE and MAX-VALUE arguments of `make-progress-reporter' can
740now be nil, or omitted. This makes a "non-numeric" reporter. Each
741time you call `progress-reporter-update' on that progress reporter,
742with a nil or omitted VALUE argument, the reporter message is
743displayed with a "spinning bar".
744
eb199145
GM
745\f
746* Changes in Emacs 24.1 on non-free operating systems
d53a60a6 747
04779484
JB
748** New configure.bat option --enable-checking builds emacs with extra
749runtime checks.
750
e3aef5c6
CS
751** New configure.bat option --distfiles to specify files to be
752 included in binary distribution
753
754** New make target `dist' to create binary disttribution for Windows
755 platform
756
05197f40 757\f
a933dad1 758----------------------------------------------------------------------
5b87ad55 759This file is part of GNU Emacs.
a933dad1 760
ab73e885 761GNU Emacs is free software: you can redistribute it and/or modify
5b87ad55 762it under the terms of the GNU General Public License as published by
ab73e885
GM
763the Free Software Foundation, either version 3 of the License, or
764(at your option) any later version.
5b87ad55
GM
765
766GNU Emacs is distributed in the hope that it will be useful,
767but WITHOUT ANY WARRANTY; without even the implied warranty of
768MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
769GNU General Public License for more details.
a933dad1 770
5b87ad55 771You should have received a copy of the GNU General Public License
ab73e885 772along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
a933dad1 773
05197f40 774\f
a933dad1
DL
775Local variables:
776mode: outline
777paragraph-separate: "[ \f]*$"
778end: