Mercurial > emacs
annotate lisp/desktop.el @ 88310:3a8dcdafba19
(rmail-convert-mbox-format): Handle mails without subject.
author | Alex Schroeder <alex@gnu.org> |
---|---|
date | Wed, 01 Feb 2006 19:26:18 +0000 |
parents | d7ddb3e565de |
children |
rev | line source |
---|---|
3404 | 1 ;;; desktop.el --- save partial status of Emacs when killed |
2 | |
88155 | 3 ;; Copyright (C) 1993, 1994, 1995, 1997, 2000, 2001, 2002, 2003, |
4 ;; 2004, 2005 Free Software Foundation, Inc. | |
3404 | 5 |
6 ;; Author: Morten Welinder <terra@diku.dk> | |
88155 | 7 ;; Maintainter: Lars Hansen <larsh@soem.dk> |
27577 | 8 ;; Keywords: convenience |
5314 | 9 ;; Favourite-brand-of-beer: None, I hate beer. |
3404 | 10 |
11 ;; This file is part of GNU Emacs. | |
12 | |
13 ;; GNU Emacs is free software; you can redistribute it and/or modify | |
14 ;; it under the terms of the GNU General Public License as published by | |
15 ;; the Free Software Foundation; either version 2, or (at your option) | |
16 ;; any later version. | |
17 | |
18 ;; GNU Emacs is distributed in the hope that it will be useful, | |
19 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
20 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
21 ;; GNU General Public License for more details. | |
22 | |
23 ;; You should have received a copy of the GNU General Public License | |
14169 | 24 ;; along with GNU Emacs; see the file COPYING. If not, write to the |
88155 | 25 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
26 ;; Boston, MA 02110-1301, USA. | |
3404 | 27 |
28 ;;; Commentary: | |
29 | |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
30 ;; Save the Desktop, i.e., |
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
31 ;; - some global variables |
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
32 ;; - the list of buffers with associated files. For each buffer also |
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
33 ;; - the major mode |
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
34 ;; - the default directory |
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
35 ;; - the point |
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
36 ;; - the mark & mark-active |
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
37 ;; - buffer-read-only |
5465
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
38 ;; - some local variables |
3404 | 39 |
88155 | 40 ;; To use this, use customize to turn on desktop-save-mode or add the |
41 ;; following line somewhere in your .emacs file: | |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
42 ;; |
88155 | 43 ;; (desktop-save-mode 1) |
5465
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
44 ;; |
88155 | 45 ;; For further usage information, look at the section |
46 ;; "Saving Emacs Sessions" in the GNU Emacs Manual. | |
47 | |
48 ;; When the desktop module is loaded, the function `desktop-kill' is | |
49 ;; added to the `kill-emacs-hook'. This function is responsible for | |
50 ;; saving the desktop when Emacs is killed. Furthermore an anonymous | |
51 ;; function is added to the `after-init-hook'. This function is | |
52 ;; responsible for loading the desktop when Emacs is started. | |
53 | |
54 ;; Special handling. | |
55 ;; ----------------- | |
56 ;; Variables `desktop-buffer-mode-handlers' and `desktop-minor-mode-handlers' | |
57 ;; are supplied to handle special major and minor modes respectively. | |
58 ;; `desktop-buffer-mode-handlers' is an alist of major mode specific functions | |
59 ;; to restore a desktop buffer. Elements must have the form | |
60 ;; | |
61 ;; (MAJOR-MODE . RESTORE-BUFFER-FUNCTION). | |
62 ;; | |
63 ;; Functions listed are called by `desktop-create-buffer' when `desktop-read' | |
64 ;; evaluates the desktop file. Buffers with a major mode not specified here, | |
65 ;; are restored by the default handler `desktop-restore-file-buffer'. | |
66 ;; `desktop-minor-mode-handlers' is an alist of functions to restore | |
67 ;; non-standard minor modes. Elements must have the form | |
68 ;; | |
69 ;; (MINOR-MODE . RESTORE-FUNCTION). | |
70 ;; | |
71 ;; Functions are called by `desktop-create-buffer' to restore minor modes. | |
72 ;; Minor modes not specified here, are restored by the standard minor mode | |
73 ;; function. If you write a module that defines a major or minor mode that | |
74 ;; needs a special handler, then place code like | |
3404 | 75 |
88155 | 76 ;; (defun foo-restore-desktop-buffer |
77 ;; ... | |
78 ;; (add-to-list 'desktop-buffer-mode-handlers | |
79 ;; '(foo-mode . foo-restore-desktop-buffer)) | |
80 | |
81 ;; or | |
82 | |
83 ;; (defun bar-desktop-restore | |
84 ;; ... | |
85 ;; (add-to-list 'desktop-minor-mode-handlers | |
86 ;; '(bar-mode . bar-desktop-restore)) | |
87 | |
88 ;; in the module itself, and make shure that the mode function is | |
89 ;; autoloaded. See the docstrings of `desktop-buffer-mode-handlers' and | |
90 ;; `desktop-minor-mode-handlers' for more info. | |
5465
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
91 |
88155 | 92 ;; Minor modes. |
93 ;; ------------ | |
94 ;; Conventional minor modes (see node "Minor Mode Conventions" in the elisp | |
95 ;; manual) are handled in the following way: | |
96 ;; When `desktop-save' saves the state of a buffer to the desktop file, it | |
97 ;; saves as `desktop-minor-modes' the list of names of those variables in | |
98 ;; `minor-mode-alist' that have a non-nil value. | |
99 ;; When `desktop-create' restores the buffer, each of the symbols in | |
100 ;; `desktop-minor-modes' is called as function with parameter 1. | |
101 ;; The variables `desktop-minor-mode-table' and `desktop-minor-mode-handlers' | |
102 ;; are used to handle non-conventional minor modes. `desktop-save' uses | |
103 ;; `desktop-minor-mode-table' to map minor mode variables to minor mode | |
104 ;; functions before writing `desktop-minor-modes'. If a minor mode has a | |
105 ;; variable name that is different form its function name, an entry | |
106 | |
107 ;; (NAME RESTORE-FUNCTION) | |
108 | |
109 ;; should be added to `desktop-minor-mode-table'. If a minor mode should not | |
110 ;; be restored, RESTORE-FUNCTION should be set to nil. `desktop-create' uses | |
111 ;; `desktop-minor-mode-handlers' to lookup minor modes that needs a restore | |
112 ;; function different from the usual minor mode function. | |
113 ;; --------------------------------------------------------------------------- | |
28719
f56c181fb849
(desktop-save): Save list of minor modes.
Gerd Moellmann <gerd@gnu.org>
parents:
27577
diff
changeset
|
114 |
5465
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
115 ;; By the way: don't use desktop.el to customize Emacs -- the file .emacs |
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
116 ;; in your home directory is used for that. Saving global default values |
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
117 ;; for buffers is an example of misuse. |
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
118 |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
119 ;; PLEASE NOTE: The kill ring can be saved as specified by the variable |
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
120 ;; `desktop-globals-to-save' (by default it isn't). This may result in saving |
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
121 ;; things you did not mean to keep. Use M-x desktop-clear RET. |
5465
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
122 |
7240
195e64dad1eb
(desktop-files-not-to-save): New variable to exclude certain files -- magic
Karl Heuer <kwzh@gnu.org>
parents:
7200
diff
changeset
|
123 ;; Thanks to hetrick@phys.uva.nl (Jim Hetrick) for useful ideas. |
195e64dad1eb
(desktop-files-not-to-save): New variable to exclude certain files -- magic
Karl Heuer <kwzh@gnu.org>
parents:
7200
diff
changeset
|
124 ;; avk@rtsg.mot.com (Andrew V. Klein) for a dired tip. |
195e64dad1eb
(desktop-files-not-to-save): New variable to exclude certain files -- magic
Karl Heuer <kwzh@gnu.org>
parents:
7200
diff
changeset
|
125 ;; chris@tecc.co.uk (Chris Boucher) for a mark tip. |
195e64dad1eb
(desktop-files-not-to-save): New variable to exclude certain files -- magic
Karl Heuer <kwzh@gnu.org>
parents:
7200
diff
changeset
|
126 ;; f89-kam@nada.kth.se (Klas Mellbourn) for a mh-e tip. |
195e64dad1eb
(desktop-files-not-to-save): New variable to exclude certain files -- magic
Karl Heuer <kwzh@gnu.org>
parents:
7200
diff
changeset
|
127 ;; kifer@sbkifer.cs.sunysb.edu (M. Kifer) for a bug hunt. |
11224
f7f101a90cd4
(desktop-save): Use dired-directory as name
Richard M. Stallman <rms@gnu.org>
parents:
10777
diff
changeset
|
128 ;; treese@lcs.mit.edu (Win Treese) for ange-ftp tips. |
14172
da563949c7d7
(desktop-read): Do nothing in batch mode.
Richard M. Stallman <rms@gnu.org>
parents:
14169
diff
changeset
|
129 ;; pot@cnuce.cnr.it (Francesco Potorti`) for misc. tips. |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
130 ;; --------------------------------------------------------------------------- |
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
131 ;; TODO: |
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
132 ;; |
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
133 ;; Save window configuration. |
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
134 ;; Recognize more minor modes. |
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
135 ;; Save mark rings. |
3404 | 136 |
137 ;;; Code: | |
138 | |
88155 | 139 (defvar desktop-file-version "206" |
140 "Version number of desktop file format. | |
141 Written into the desktop file and used at desktop read to provide | |
142 backward compatibility.") | |
143 | |
5465
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
144 ;; ---------------------------------------------------------------------------- |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
145 ;; USER OPTIONS -- settings you might want to play with. |
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
146 ;; ---------------------------------------------------------------------------- |
17411
f0ff96a35eb8
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
17204
diff
changeset
|
147 |
f0ff96a35eb8
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
17204
diff
changeset
|
148 (defgroup desktop nil |
f0ff96a35eb8
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
17204
diff
changeset
|
149 "Save status of Emacs when you exit." |
f0ff96a35eb8
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
17204
diff
changeset
|
150 :group 'frames) |
f0ff96a35eb8
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
17204
diff
changeset
|
151 |
88155 | 152 ;;;###autoload |
153 (define-minor-mode desktop-save-mode | |
154 "Toggle desktop saving mode. | |
155 With numeric ARG, turn desktop saving on if ARG is positive, off | |
156 otherwise. See variable `desktop-save' for a description of when the | |
157 desktop is saved." | |
158 :global t | |
17411
f0ff96a35eb8
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
17204
diff
changeset
|
159 :group 'desktop) |
3404 | 160 |
88155 | 161 ;; Maintained for backward compatibility |
162 (define-obsolete-variable-alias 'desktop-enable | |
163 'desktop-save-mode "22.1") | |
164 | |
165 (defcustom desktop-save 'ask-if-new | |
166 "*Specifies whether the desktop should be saved when it is killed. | |
167 A desktop is killed when the user changes desktop or quits Emacs. | |
168 Possible values are: | |
169 t -- always save. | |
170 ask -- always ask. | |
171 ask-if-new -- ask if no desktop file exists, otherwise just save. | |
172 ask-if-exists -- ask if desktop file exists, otherwise don't save. | |
173 if-exists -- save if desktop file exists, otherwise don't save. | |
174 nil -- never save. | |
175 The desktop is never saved when `desktop-save-mode' is nil. | |
176 The variables `desktop-dirname' and `desktop-base-file-name' | |
177 determine where the desktop is saved." | |
178 :type '(choice | |
179 (const :tag "Always save" t) | |
180 (const :tag "Always ask" ask) | |
181 (const :tag "Ask if desktop file is new, else do save" ask-if-new) | |
182 (const :tag "Ask if desktop file exists, else don't save" ask-if-exists) | |
183 (const :tag "Save if desktop file exists, else don't" if-exists) | |
184 (const :tag "Never save" nil)) | |
185 :group 'desktop | |
186 :version "22.1") | |
187 | |
188 (defcustom desktop-base-file-name | |
189 (convert-standard-filename ".emacs.desktop") | |
190 "Name of file for Emacs desktop, excluding the directory part." | |
191 :type 'file | |
192 :group 'desktop) | |
193 (define-obsolete-variable-alias 'desktop-basefilename | |
194 'desktop-base-file-name "22.1") | |
195 | |
196 (defcustom desktop-path '("." "~") | |
197 "List of directories to search for the desktop file. | |
198 The base name of the file is specified in `desktop-base-file-name'." | |
199 :type '(repeat directory) | |
200 :group 'desktop | |
201 :version "22.1") | |
202 | |
203 (defcustom desktop-missing-file-warning nil | |
204 "*If non-nil then `desktop-read' asks if a non-existent file should be recreated. | |
205 Also pause for a moment to display message about errors signaled in | |
206 `desktop-buffer-mode-handlers'. | |
207 | |
208 If nil, just print error messages in the message buffer." | |
209 :type 'boolean | |
210 :group 'desktop | |
211 :version "22.1") | |
212 | |
213 (defcustom desktop-no-desktop-file-hook nil | |
214 "Normal hook run when `desktop-read' can't find a desktop file. | |
215 May be used to show a dired buffer." | |
216 :type 'hook | |
217 :group 'desktop | |
218 :version "22.1") | |
219 | |
220 (defcustom desktop-after-read-hook nil | |
221 "Normal hook run after a successful `desktop-read'. | |
222 May be used to show a buffer list." | |
223 :type 'hook | |
224 :group 'desktop | |
225 :version "22.1") | |
3404 | 226 |
88155 | 227 (defcustom desktop-save-hook nil |
228 "Normal hook run before the desktop is saved in a desktop file. | |
229 This is useful for truncating history lists, for example." | |
230 :type 'hook | |
231 :group 'desktop) | |
232 | |
233 (defcustom desktop-globals-to-save | |
234 '(desktop-missing-file-warning | |
235 tags-file-name | |
236 tags-table-list | |
237 search-ring | |
238 regexp-search-ring | |
239 register-alist) | |
240 "List of global variables saved by `desktop-save'. | |
241 An element may be variable name (a symbol) or a cons cell of the form | |
242 \(VAR . MAX-SIZE), which means to truncate VAR's value to at most | |
243 MAX-SIZE elements (if the value is a list) before saving the value. | |
244 Feature: Saving `kill-ring' implies saving `kill-ring-yank-pointer'." | |
245 :type '(repeat (restricted-sexp :match-alternatives (symbolp consp))) | |
246 :group 'desktop) | |
247 | |
248 (defcustom desktop-globals-to-clear | |
249 '(kill-ring | |
250 kill-ring-yank-pointer | |
251 search-ring | |
252 search-ring-yank-pointer | |
253 regexp-search-ring | |
254 regexp-search-ring-yank-pointer) | |
255 "List of global variables that `desktop-clear' will clear. | |
256 An element may be variable name (a symbol) or a cons cell of the form | |
257 \(VAR . FORM). Symbols are set to nil and for cons cells VAR is set | |
258 to the value obtained by evaluating FORM." | |
259 :type '(repeat (restricted-sexp :match-alternatives (symbolp consp))) | |
260 :group 'desktop | |
261 :version "22.1") | |
262 | |
263 (defcustom desktop-clear-preserve-buffers | |
264 '("\\*scratch\\*" "\\*Messages\\*" "\\*server\\*" "\\*tramp/.+\\*") | |
265 "*List of buffers that `desktop-clear' should not delete. | |
266 Each element is a regular expression. Buffers with a name matched by any of | |
267 these won't be deleted." | |
268 :type '(repeat string) | |
269 :group 'desktop) | |
270 | |
271 ;;;###autoload | |
272 (defcustom desktop-locals-to-save | |
273 '(desktop-locals-to-save ; Itself! Think it over. | |
274 truncate-lines | |
275 case-fold-search | |
276 case-replace | |
277 fill-column | |
278 overwrite-mode | |
279 change-log-default-name | |
280 line-number-mode | |
281 column-number-mode | |
282 size-indication-mode | |
283 buffer-file-coding-system | |
284 indent-tabs-mode | |
285 indicate-buffer-boundaries | |
286 indicate-empty-lines | |
287 show-trailing-whitespace) | |
10595 | 288 "List of local variables to save for each buffer. |
88155 | 289 The variables are saved only when they really are local. Conventional minor |
290 modes are restored automatically; they should not be listed here." | |
291 :type '(repeat symbol) | |
292 :group 'desktop) | |
5465
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
293 |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
294 ;; We skip .log files because they are normally temporary. |
14040 | 295 ;; (ftp) files because they require passwords and whatnot. |
17411
f0ff96a35eb8
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
17204
diff
changeset
|
296 (defcustom desktop-buffers-not-to-save |
88155 | 297 "\\(^nn\\.a[0-9]+\\|\\.log\\|(ftp)\\)$" |
298 "Regexp identifying buffers that are to be excluded from saving." | |
299 :type 'regexp | |
300 :group 'desktop) | |
3404 | 301 |
88155 | 302 ;; Skip tramp and ange-ftp files |
17411
f0ff96a35eb8
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
17204
diff
changeset
|
303 (defcustom desktop-files-not-to-save |
7240
195e64dad1eb
(desktop-files-not-to-save): New variable to exclude certain files -- magic
Karl Heuer <kwzh@gnu.org>
parents:
7200
diff
changeset
|
304 "^/[^/:]*:" |
17411
f0ff96a35eb8
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
17204
diff
changeset
|
305 "Regexp identifying files whose buffers are to be excluded from saving." |
f0ff96a35eb8
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
17204
diff
changeset
|
306 :type 'regexp |
f0ff96a35eb8
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
17204
diff
changeset
|
307 :group 'desktop) |
7240
195e64dad1eb
(desktop-files-not-to-save): New variable to exclude certain files -- magic
Karl Heuer <kwzh@gnu.org>
parents:
7200
diff
changeset
|
308 |
88155 | 309 ;; We skip TAGS files to save time (tags-file-name is saved instead). |
310 (defcustom desktop-modes-not-to-save | |
311 '(tags-table-mode) | |
32366
40d8b29df57e
(desktop-modes-not-to-save): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
30853
diff
changeset
|
312 "List of major modes whose buffers should not be saved." |
40d8b29df57e
(desktop-modes-not-to-save): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
30853
diff
changeset
|
313 :type '(repeat symbol) |
40d8b29df57e
(desktop-modes-not-to-save): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
30853
diff
changeset
|
314 :group 'desktop) |
40d8b29df57e
(desktop-modes-not-to-save): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
30853
diff
changeset
|
315 |
88155 | 316 (defcustom desktop-file-name-format 'absolute |
317 "*Format in which desktop file names should be saved. | |
318 Possible values are: | |
319 absolute -- Absolute file name. | |
320 tilde -- Relative to ~. | |
321 local -- Relative to directory of desktop file." | |
322 :type '(choice (const absolute) (const tilde) (const local)) | |
323 :group 'desktop | |
324 :version "22.1") | |
14755
3d473ed8c718
Global vars mam, fn, bn renamed.
Richard M. Stallman <rms@gnu.org>
parents:
14754
diff
changeset
|
325 |
88155 | 326 (defcustom desktop-restore-eager t |
327 "Number of buffers to restore immediately. | |
328 Remaining buffers are restored lazily (when Emacs is idle). | |
329 If value is t, all buffers are restored immediately." | |
330 :type '(choice (const t) integer) | |
331 :group 'desktop | |
332 :version "22.1") | |
14755
3d473ed8c718
Global vars mam, fn, bn renamed.
Richard M. Stallman <rms@gnu.org>
parents:
14754
diff
changeset
|
333 |
88155 | 334 (defcustom desktop-lazy-verbose t |
335 "Verbose reporting of lazily created buffers." | |
336 :type 'boolean | |
337 :group 'desktop | |
338 :version "22.1") | |
14755
3d473ed8c718
Global vars mam, fn, bn renamed.
Richard M. Stallman <rms@gnu.org>
parents:
14754
diff
changeset
|
339 |
88155 | 340 (defcustom desktop-lazy-idle-delay 5 |
341 "Idle delay before starting to create buffers. | |
342 See `desktop-restore-eager'." | |
343 :type 'integer | |
344 :group 'desktop | |
345 :version "22.1") | |
14756
aabf776c3b6a
Global var `misc' renamed.
Richard M. Stallman <rms@gnu.org>
parents:
14755
diff
changeset
|
346 |
88155 | 347 ;;;###autoload |
348 (defvar desktop-save-buffer nil | |
349 "When non-nil, save buffer status in desktop file. | |
350 This variable becomes buffer local when set. | |
351 | |
352 If the value is a function, it is called by `desktop-save' with argument | |
353 DESKTOP-DIRNAME to obtain auxiliary information to save in the desktop | |
354 file along with the state of the buffer for which it was called. | |
355 | |
356 When file names are returned, they should be formatted using the call | |
357 \"(desktop-file-name FILE-NAME DESKTOP-DIRNAME)\". | |
32447
cfae1c82d702
Added extensible special buffer support to desktop.el. See the
John Wiegley <johnw@newartisans.com>
parents:
32366
diff
changeset
|
358 |
88155 | 359 Later, when `desktop-read' evaluates the desktop file, auxiliary information |
360 is passed as the argument DESKTOP-BUFFER-MISC to functions in | |
361 `desktop-buffer-mode-handlers'.") | |
362 (make-variable-buffer-local 'desktop-save-buffer) | |
363 (make-obsolete-variable 'desktop-buffer-modes-to-save | |
364 'desktop-save-buffer "22.1") | |
365 (make-obsolete-variable 'desktop-buffer-misc-functions | |
366 'desktop-save-buffer "22.1") | |
367 | |
368 ;;;###autoload | |
369 (defvar desktop-buffer-mode-handlers | |
370 nil | |
371 "Alist of major mode specific functions to restore a desktop buffer. | |
372 Functions listed are called by `desktop-create-buffer' when `desktop-read' | |
373 evaluates the desktop file. List elements must have the form | |
374 | |
375 (MAJOR-MODE . RESTORE-BUFFER-FUNCTION). | |
376 | |
377 Buffers with a major mode not specified here, are restored by the default | |
378 handler `desktop-restore-file-buffer'. | |
379 | |
380 Handlers are called with argument list | |
381 | |
382 (DESKTOP-BUFFER-FILE-NAME DESKTOP-BUFFER-NAME DESKTOP-BUFFER-MISC) | |
32447
cfae1c82d702
Added extensible special buffer support to desktop.el. See the
John Wiegley <johnw@newartisans.com>
parents:
32366
diff
changeset
|
383 |
88155 | 384 Furthermore, they may use the following variables: |
385 | |
386 desktop-file-version | |
387 desktop-buffer-major-mode | |
388 desktop-buffer-minor-modes | |
389 desktop-buffer-point | |
390 desktop-buffer-mark | |
391 desktop-buffer-read-only | |
392 desktop-buffer-locals | |
393 | |
394 If a handler returns a buffer, then the saved mode settings | |
395 and variable values for that buffer are copied into it. | |
5465
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
396 |
88155 | 397 Modules that define a major mode that needs a special handler should contain |
398 code like | |
7240
195e64dad1eb
(desktop-files-not-to-save): New variable to exclude certain files -- magic
Karl Heuer <kwzh@gnu.org>
parents:
7200
diff
changeset
|
399 |
88155 | 400 (defun foo-restore-desktop-buffer |
401 ... | |
402 (add-to-list 'desktop-buffer-mode-handlers | |
403 '(foo-mode . foo-restore-desktop-buffer)) | |
404 | |
405 Furthermore the major mode function must be autoloaded.") | |
406 | |
407 ;;;###autoload | |
408 (put 'desktop-buffer-mode-handlers 'risky-local-variable t) | |
409 (make-obsolete-variable 'desktop-buffer-handlers | |
410 'desktop-buffer-mode-handlers "22.1") | |
20526
ec0a8ccddd6c
(desktop-enable): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18581
diff
changeset
|
411 |
28719
f56c181fb849
(desktop-save): Save list of minor modes.
Gerd Moellmann <gerd@gnu.org>
parents:
27577
diff
changeset
|
412 (defcustom desktop-minor-mode-table |
f56c181fb849
(desktop-save): Save list of minor modes.
Gerd Moellmann <gerd@gnu.org>
parents:
27577
diff
changeset
|
413 '((auto-fill-function auto-fill-mode) |
88155 | 414 (vc-mode nil) |
415 (vc-dired-mode nil)) | |
28719
f56c181fb849
(desktop-save): Save list of minor modes.
Gerd Moellmann <gerd@gnu.org>
parents:
27577
diff
changeset
|
416 "Table mapping minor mode variables to minor mode functions. |
f56c181fb849
(desktop-save): Save list of minor modes.
Gerd Moellmann <gerd@gnu.org>
parents:
27577
diff
changeset
|
417 Each entry has the form (NAME RESTORE-FUNCTION). |
f56c181fb849
(desktop-save): Save list of minor modes.
Gerd Moellmann <gerd@gnu.org>
parents:
27577
diff
changeset
|
418 NAME is the name of the buffer-local variable indicating that the minor |
f56c181fb849
(desktop-save): Save list of minor modes.
Gerd Moellmann <gerd@gnu.org>
parents:
27577
diff
changeset
|
419 mode is active. RESTORE-FUNCTION is the function to activate the minor mode. |
f56c181fb849
(desktop-save): Save list of minor modes.
Gerd Moellmann <gerd@gnu.org>
parents:
27577
diff
changeset
|
420 called. RESTORE-FUNCTION nil means don't try to restore the minor mode. |
f56c181fb849
(desktop-save): Save list of minor modes.
Gerd Moellmann <gerd@gnu.org>
parents:
27577
diff
changeset
|
421 Only minor modes for which the name of the buffer-local variable |
88155 | 422 and the name of the minor mode function are different have to be added to |
423 this table. See also `desktop-minor-mode-handlers'." | |
28719
f56c181fb849
(desktop-save): Save list of minor modes.
Gerd Moellmann <gerd@gnu.org>
parents:
27577
diff
changeset
|
424 :type 'sexp |
f56c181fb849
(desktop-save): Save list of minor modes.
Gerd Moellmann <gerd@gnu.org>
parents:
27577
diff
changeset
|
425 :group 'desktop) |
f56c181fb849
(desktop-save): Save list of minor modes.
Gerd Moellmann <gerd@gnu.org>
parents:
27577
diff
changeset
|
426 |
88155 | 427 ;;;###autoload |
428 (defvar desktop-minor-mode-handlers | |
429 nil | |
430 "Alist of functions to restore non-standard minor modes. | |
431 Functions are called by `desktop-create-buffer' to restore minor modes. | |
432 List elements must have the form | |
433 | |
434 (MINOR-MODE . RESTORE-FUNCTION). | |
435 | |
436 Minor modes not specified here, are restored by the standard minor mode | |
437 function. | |
438 | |
439 Handlers are called with argument list | |
440 | |
441 (DESKTOP-BUFFER-LOCALS) | |
442 | |
443 Furthermore, they may use the following variables: | |
444 | |
445 desktop-file-version | |
446 desktop-buffer-file-name | |
447 desktop-buffer-name | |
448 desktop-buffer-major-mode | |
449 desktop-buffer-minor-modes | |
450 desktop-buffer-point | |
451 desktop-buffer-mark | |
452 desktop-buffer-read-only | |
453 desktop-buffer-misc | |
454 | |
455 When a handler is called, the buffer has been created and the major mode has | |
456 been set, but local variables listed in desktop-buffer-locals has not yet been | |
457 created and set. | |
458 | |
459 Modules that define a minor mode that needs a special handler should contain | |
460 code like | |
461 | |
462 (defun foo-desktop-restore | |
463 ... | |
464 (add-to-list 'desktop-minor-mode-handlers | |
465 '(foo-mode . foo-desktop-restore)) | |
466 | |
467 Furthermore the minor mode function must be autoloaded. | |
468 | |
469 See also `desktop-minor-mode-table'.") | |
470 | |
471 ;;;###autoload | |
472 (put 'desktop-minor-mode-handlers 'risky-local-variable t) | |
473 | |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
474 ;; ---------------------------------------------------------------------------- |
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
475 (defvar desktop-dirname nil |
88155 | 476 "The directory in which the desktop file should be saved.") |
3404 | 477 |
478 (defconst desktop-header | |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
479 ";; -------------------------------------------------------------------------- |
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
480 ;; Desktop File for Emacs |
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
481 ;; -------------------------------------------------------------------------- |
3404 | 482 " "*Header to place in Desktop file.") |
5788
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
483 |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
484 (defvar desktop-delay-hook nil |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
485 "Hooks run after all buffers are loaded; intended for internal use.") |
20526
ec0a8ccddd6c
(desktop-enable): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18581
diff
changeset
|
486 |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
487 ;; ---------------------------------------------------------------------------- |
88155 | 488 (defun desktop-truncate (list n) |
5465
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
489 "Truncate LIST to at most N elements destructively." |
88155 | 490 (let ((here (nthcdr (1- n) list))) |
5465
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
491 (if (consp here) |
5788
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
492 (setcdr here nil)))) |
88155 | 493 |
5465
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
494 ;; ---------------------------------------------------------------------------- |
18581
45f27efe77c7
(desktop-clear-preserve-buffers): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18527
diff
changeset
|
495 (defun desktop-clear () |
45f27efe77c7
(desktop-clear-preserve-buffers): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18527
diff
changeset
|
496 "Empty the Desktop. |
88155 | 497 This kills all buffers except for internal ones and those with names matched by |
498 a regular expression in the list `desktop-clear-preserve-buffers'. | |
499 Furthermore, it clears the variables listed in `desktop-globals-to-clear'." | |
3404 | 500 (interactive) |
88155 | 501 (desktop-lazy-abort) |
502 (dolist (var desktop-globals-to-clear) | |
503 (if (symbolp var) | |
504 (eval `(setq-default ,var nil)) | |
505 (eval `(setq-default ,(car var) ,(cdr var))))) | |
506 (let ((buffers (buffer-list)) | |
507 (preserve-regexp (concat "^\\(" | |
508 (mapconcat (lambda (regexp) | |
509 (concat "\\(" regexp "\\)")) | |
510 desktop-clear-preserve-buffers | |
511 "\\|") | |
512 "\\)$"))) | |
18581
45f27efe77c7
(desktop-clear-preserve-buffers): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18527
diff
changeset
|
513 (while buffers |
88155 | 514 (let ((bufname (buffer-name (car buffers)))) |
515 (or | |
516 (null bufname) | |
517 (string-match preserve-regexp bufname) | |
518 ;; Don't kill buffers made for internal purposes. | |
519 (and (not (equal bufname "")) (eq (aref bufname 0) ?\s)) | |
520 (kill-buffer (car buffers)))) | |
18581
45f27efe77c7
(desktop-clear-preserve-buffers): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18527
diff
changeset
|
521 (setq buffers (cdr buffers)))) |
5314 | 522 (delete-other-windows)) |
88155 | 523 |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
524 ;; ---------------------------------------------------------------------------- |
5788
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
525 (add-hook 'kill-emacs-hook 'desktop-kill) |
5465
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
526 |
3404 | 527 (defun desktop-kill () |
88155 | 528 "If `desktop-save-mode' is non-nil, do what `desktop-save' says to do. |
529 If the desktop should be saved and `desktop-dirname' | |
530 is nil, ask the user where to save the desktop." | |
531 (when | |
532 (and | |
533 desktop-save-mode | |
534 (let ((exists (file-exists-p (expand-file-name desktop-base-file-name desktop-dirname)))) | |
535 (or | |
536 (eq desktop-save t) | |
537 (and exists (memq desktop-save '(ask-if-new if-exists))) | |
538 (and | |
539 (or | |
540 (memq desktop-save '(ask ask-if-new)) | |
541 (and exists (eq desktop-save 'ask-if-exists))) | |
542 (y-or-n-p "Save desktop? "))))) | |
543 (unless desktop-dirname | |
544 (setq desktop-dirname | |
545 (file-name-as-directory | |
546 (expand-file-name | |
547 (call-interactively | |
548 (lambda (dir) (interactive "DDirectory for desktop file: ") dir)))))) | |
549 (condition-case err | |
550 (desktop-save desktop-dirname) | |
551 (file-error | |
552 (unless (yes-or-no-p "Error while saving the desktop. Ignore? ") | |
553 (signal (car err) (cdr err))))))) | |
554 | |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
555 ;; ---------------------------------------------------------------------------- |
14754
9955249f9b0f
(desktop-list*): New function.
Richard M. Stallman <rms@gnu.org>
parents:
14172
diff
changeset
|
556 (defun desktop-list* (&rest args) |
9955249f9b0f
(desktop-list*): New function.
Richard M. Stallman <rms@gnu.org>
parents:
14172
diff
changeset
|
557 (if (null (cdr args)) |
9955249f9b0f
(desktop-list*): New function.
Richard M. Stallman <rms@gnu.org>
parents:
14172
diff
changeset
|
558 (car args) |
9955249f9b0f
(desktop-list*): New function.
Richard M. Stallman <rms@gnu.org>
parents:
14172
diff
changeset
|
559 (setq args (nreverse args)) |
9955249f9b0f
(desktop-list*): New function.
Richard M. Stallman <rms@gnu.org>
parents:
14172
diff
changeset
|
560 (let ((value (cons (nth 1 args) (car args)))) |
9955249f9b0f
(desktop-list*): New function.
Richard M. Stallman <rms@gnu.org>
parents:
14172
diff
changeset
|
561 (setq args (cdr (cdr args))) |
9955249f9b0f
(desktop-list*): New function.
Richard M. Stallman <rms@gnu.org>
parents:
14172
diff
changeset
|
562 (while args |
9955249f9b0f
(desktop-list*): New function.
Richard M. Stallman <rms@gnu.org>
parents:
14172
diff
changeset
|
563 (setq value (cons (car args) value)) |
9955249f9b0f
(desktop-list*): New function.
Richard M. Stallman <rms@gnu.org>
parents:
14172
diff
changeset
|
564 (setq args (cdr args))) |
9955249f9b0f
(desktop-list*): New function.
Richard M. Stallman <rms@gnu.org>
parents:
14172
diff
changeset
|
565 value))) |
9955249f9b0f
(desktop-list*): New function.
Richard M. Stallman <rms@gnu.org>
parents:
14172
diff
changeset
|
566 |
88155 | 567 ;; ---------------------------------------------------------------------------- |
568 (defun desktop-internal-v2s (value) | |
10595 | 569 "Convert VALUE to a pair (QUOTE . TXT); (eval (read TXT)) gives VALUE. |
570 TXT is a string that when read and evaluated yields value. | |
571 QUOTE may be `may' (value may be quoted), | |
572 `must' (values must be quoted), or nil (value may not be quoted)." | |
5788
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
573 (cond |
88155 | 574 ((or (numberp value) (null value) (eq t value) (keywordp value)) |
575 (cons 'may (prin1-to-string value))) | |
576 ((stringp value) | |
577 (let ((copy (copy-sequence value))) | |
10777
9f4a9820fea1
(desktop-internal-v2s): Don't use format to eliminate text properties.
Richard M. Stallman <rms@gnu.org>
parents:
10595
diff
changeset
|
578 (set-text-properties 0 (length copy) nil copy) |
9f4a9820fea1
(desktop-internal-v2s): Don't use format to eliminate text properties.
Richard M. Stallman <rms@gnu.org>
parents:
10595
diff
changeset
|
579 ;; Get rid of text properties because we cannot read them |
9f4a9820fea1
(desktop-internal-v2s): Don't use format to eliminate text properties.
Richard M. Stallman <rms@gnu.org>
parents:
10595
diff
changeset
|
580 (cons 'may (prin1-to-string copy)))) |
88155 | 581 ((symbolp value) |
582 (cons 'must (prin1-to-string value))) | |
583 ((vectorp value) | |
5788
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
584 (let* ((special nil) |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
585 (pass1 (mapcar |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
586 (lambda (el) |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
587 (let ((res (desktop-internal-v2s el))) |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
588 (if (null (car res)) |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
589 (setq special t)) |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
590 res)) |
88155 | 591 value))) |
5788
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
592 (if special |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
593 (cons nil (concat "(vector " |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
594 (mapconcat (lambda (el) |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
595 (if (eq (car el) 'must) |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
596 (concat "'" (cdr el)) |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
597 (cdr el))) |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
598 pass1 |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
599 " ") |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
600 ")")) |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
601 (cons 'may (concat "[" (mapconcat 'cdr pass1 " ") "]"))))) |
88155 | 602 ((consp value) |
603 (let ((p value) | |
7200
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
604 newlist |
14754
9955249f9b0f
(desktop-list*): New function.
Richard M. Stallman <rms@gnu.org>
parents:
14172
diff
changeset
|
605 use-list* |
7200
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
606 anynil) |
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
607 (while (consp p) |
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
608 (let ((q.txt (desktop-internal-v2s (car p)))) |
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
609 (or anynil (setq anynil (null (car q.txt)))) |
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
610 (setq newlist (cons q.txt newlist))) |
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
611 (setq p (cdr p))) |
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
612 (if p |
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
613 (let ((last (desktop-internal-v2s p)) |
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
614 (el (car newlist))) |
14754
9955249f9b0f
(desktop-list*): New function.
Richard M. Stallman <rms@gnu.org>
parents:
14172
diff
changeset
|
615 (or anynil (setq anynil (null (car last)))) |
9955249f9b0f
(desktop-list*): New function.
Richard M. Stallman <rms@gnu.org>
parents:
14172
diff
changeset
|
616 (or anynil |
9955249f9b0f
(desktop-list*): New function.
Richard M. Stallman <rms@gnu.org>
parents:
14172
diff
changeset
|
617 (setq newlist (cons '(must . ".") newlist))) |
9955249f9b0f
(desktop-list*): New function.
Richard M. Stallman <rms@gnu.org>
parents:
14172
diff
changeset
|
618 (setq use-list* t) |
9955249f9b0f
(desktop-list*): New function.
Richard M. Stallman <rms@gnu.org>
parents:
14172
diff
changeset
|
619 (setq newlist (cons last newlist)))) |
7200
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
620 (setq newlist (nreverse newlist)) |
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
621 (if anynil |
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
622 (cons nil |
14754
9955249f9b0f
(desktop-list*): New function.
Richard M. Stallman <rms@gnu.org>
parents:
14172
diff
changeset
|
623 (concat (if use-list* "(desktop-list* " "(list ") |
7200
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
624 (mapconcat (lambda (el) |
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
625 (if (eq (car el) 'must) |
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
626 (concat "'" (cdr el)) |
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
627 (cdr el))) |
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
628 newlist |
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
629 " ") |
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
630 ")")) |
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
631 (cons 'must |
eabd5e6e95de
(desktop-internal-v2s): Default case fixed to return correct quote flag.
Richard M. Stallman <rms@gnu.org>
parents:
7091
diff
changeset
|
632 (concat "(" (mapconcat 'cdr newlist " ") ")"))))) |
88155 | 633 ((subrp value) |
5788
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
634 (cons nil (concat "(symbol-function '" |
88155 | 635 (substring (prin1-to-string value) 7 -1) |
5788
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
636 ")"))) |
88155 | 637 ((markerp value) |
638 (let ((pos (prin1-to-string (marker-position value))) | |
639 (buf (prin1-to-string (buffer-name (marker-buffer value))))) | |
5788
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
640 (cons nil (concat "(let ((mk (make-marker)))" |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
641 " (add-hook 'desktop-delay-hook" |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
642 " (list 'lambda '() (list 'set-marker mk " |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
643 pos " (get-buffer " buf ")))) mk)")))) |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
644 (t ; save as text |
7240
195e64dad1eb
(desktop-files-not-to-save): New variable to exclude certain files -- magic
Karl Heuer <kwzh@gnu.org>
parents:
7200
diff
changeset
|
645 (cons 'may "\"Unprintable entity\"")))) |
5788
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
646 |
88155 | 647 ;; ---------------------------------------------------------------------------- |
648 (defun desktop-value-to-string (value) | |
10595 | 649 "Convert VALUE to a string that when read evaluates to the same value. |
650 Not all types of values are supported." | |
5788
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
651 (let* ((print-escape-newlines t) |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
652 (float-output-format nil) |
88155 | 653 (quote.txt (desktop-internal-v2s value)) |
5788
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
654 (quote (car quote.txt)) |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
655 (txt (cdr quote.txt))) |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
656 (if (eq quote 'must) |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
657 (concat "'" txt) |
913f27480fad
(desktop-internal-v2s): Allow saving of markers and subrs.
Richard M. Stallman <rms@gnu.org>
parents:
5465
diff
changeset
|
658 txt))) |
88155 | 659 |
5465
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
660 ;; ---------------------------------------------------------------------------- |
13154
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
661 (defun desktop-outvar (varspec) |
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
662 "Output a setq statement for variable VAR to the desktop file. |
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
663 The argument VARSPEC may be the variable name VAR (a symbol), |
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
664 or a cons cell of the form (VAR . MAX-SIZE), |
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
665 which means to truncate VAR's value to at most MAX-SIZE elements |
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
666 \(if the value is a list) before saving the value." |
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
667 (let (var size) |
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
668 (if (consp varspec) |
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
669 (setq var (car varspec) size (cdr varspec)) |
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
670 (setq var varspec)) |
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
671 (if (boundp var) |
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
672 (progn |
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
673 (if (and (integerp size) |
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
674 (> size 0) |
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
675 (listp (eval var))) |
28719
f56c181fb849
(desktop-save): Save list of minor modes.
Gerd Moellmann <gerd@gnu.org>
parents:
27577
diff
changeset
|
676 (desktop-truncate (eval var) size)) |
13154
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
677 (insert "(setq " |
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
678 (symbol-name var) |
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
679 " " |
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
680 (desktop-value-to-string (symbol-value var)) |
f86e18ff3736
(desktop-outvar): Support truncation.
Richard M. Stallman <rms@gnu.org>
parents:
11224
diff
changeset
|
681 ")\n"))))) |
88155 | 682 |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
683 ;; ---------------------------------------------------------------------------- |
5465
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
684 (defun desktop-save-buffer-p (filename bufname mode &rest dummy) |
88155 | 685 "Return t if buffer should have its state saved in the desktop file. |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
686 FILENAME is the visited file name, BUFNAME is the buffer name, and |
3404 | 687 MODE is the major mode." |
7240
195e64dad1eb
(desktop-files-not-to-save): New variable to exclude certain files -- magic
Karl Heuer <kwzh@gnu.org>
parents:
7200
diff
changeset
|
688 (let ((case-fold-search nil)) |
32366
40d8b29df57e
(desktop-modes-not-to-save): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
30853
diff
changeset
|
689 (and (not (string-match desktop-buffers-not-to-save bufname)) |
88155 | 690 (not (memq mode desktop-modes-not-to-save)) |
691 (or (and filename | |
692 (not (string-match desktop-files-not-to-save filename))) | |
693 (and (eq mode 'dired-mode) | |
694 (with-current-buffer bufname | |
695 (not (string-match desktop-files-not-to-save | |
696 default-directory)))) | |
697 (and (null filename) | |
698 (with-current-buffer bufname desktop-save-buffer)))))) | |
699 | |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
700 ;; ---------------------------------------------------------------------------- |
88155 | 701 (defun desktop-file-name (filename dirname) |
702 "Convert FILENAME to format specified in `desktop-file-name-format'. | |
703 DIRNAME must be the directory in which the desktop file will be saved." | |
704 (cond | |
705 ((not filename) nil) | |
706 ((eq desktop-file-name-format 'tilde) | |
707 (let ((relative-name (file-relative-name (expand-file-name filename) "~"))) | |
708 (cond | |
709 ((file-name-absolute-p relative-name) relative-name) | |
710 ((string= "./" relative-name) "~/") | |
711 ((string= "." relative-name) "~") | |
712 (t (concat "~/" relative-name))))) | |
713 ((eq desktop-file-name-format 'local) (file-relative-name filename dirname)) | |
714 (t (expand-file-name filename)))) | |
48143
8c7919f99581
(desktop-relative-file-names): New variable.
Juanma Barranquero <lekktu@gmail.com>
parents:
43831
diff
changeset
|
715 |
88155 | 716 ;; ---------------------------------------------------------------------------- |
3404 | 717 (defun desktop-save (dirname) |
88155 | 718 "Save the desktop in a desktop file. |
719 Parameter DIRNAME specifies where to save the desktop file. | |
720 See also `desktop-base-file-name'." | |
3404 | 721 (interactive "DDirectory to save desktop file in: ") |
7240
195e64dad1eb
(desktop-files-not-to-save): New variable to exclude certain files -- magic
Karl Heuer <kwzh@gnu.org>
parents:
7200
diff
changeset
|
722 (run-hooks 'desktop-save-hook) |
88155 | 723 (setq dirname (file-name-as-directory (expand-file-name dirname))) |
3404 | 724 (save-excursion |
88155 | 725 (let ((filename (expand-file-name desktop-base-file-name dirname)) |
726 (info | |
727 (mapcar | |
728 #'(lambda (b) | |
729 (set-buffer b) | |
730 (list | |
731 (desktop-file-name (buffer-file-name) dirname) | |
732 (buffer-name) | |
733 major-mode | |
734 ;; minor modes | |
735 (let (ret) | |
736 (mapc | |
737 #'(lambda (minor-mode) | |
738 (and | |
739 (boundp minor-mode) | |
740 (symbol-value minor-mode) | |
741 (let* ((special (assq minor-mode desktop-minor-mode-table)) | |
742 (value (cond (special (cadr special)) | |
743 ((functionp minor-mode) minor-mode)))) | |
744 (when value (add-to-list 'ret value))))) | |
48143
8c7919f99581
(desktop-relative-file-names): New variable.
Juanma Barranquero <lekktu@gmail.com>
parents:
43831
diff
changeset
|
745 (mapcar #'car minor-mode-alist)) |
88155 | 746 ret) |
747 (point) | |
748 (list (mark t) mark-active) | |
749 buffer-read-only | |
750 ;; Auxiliary information | |
751 (when (functionp desktop-save-buffer) | |
752 (funcall desktop-save-buffer dirname)) | |
753 (let ((locals desktop-locals-to-save) | |
754 (loclist (buffer-local-variables)) | |
755 (ll)) | |
756 (while locals | |
757 (let ((here (assq (car locals) loclist))) | |
758 (if here | |
759 (setq ll (cons here ll)) | |
760 (when (member (car locals) loclist) | |
761 (setq ll (cons (car locals) ll))))) | |
762 (setq locals (cdr locals))) | |
763 ll))) | |
764 (buffer-list))) | |
765 (eager desktop-restore-eager) | |
766 (buf (get-buffer-create "*desktop*"))) | |
3404 | 767 (set-buffer buf) |
768 (erase-buffer) | |
7240
195e64dad1eb
(desktop-files-not-to-save): New variable to exclude certain files -- magic
Karl Heuer <kwzh@gnu.org>
parents:
7200
diff
changeset
|
769 |
88155 | 770 (insert |
771 ";; -*- mode: emacs-lisp; coding: emacs-mule; -*-\n" | |
772 desktop-header | |
773 ";; Created " (current-time-string) "\n" | |
774 ";; Desktop file format version " desktop-file-version "\n" | |
775 ";; Emacs version " emacs-version "\n\n" | |
776 ";; Global section:\n") | |
777 (mapc (function desktop-outvar) desktop-globals-to-save) | |
3404 | 778 (if (memq 'kill-ring desktop-globals-to-save) |
88155 | 779 (insert |
780 "(setq kill-ring-yank-pointer (nthcdr " | |
781 (int-to-string (- (length kill-ring) (length kill-ring-yank-pointer))) | |
782 " kill-ring))\n")) | |
3404 | 783 |
88155 | 784 (insert "\n;; Buffer section -- buffers listed in same order as in buffer list:\n") |
785 (mapc #'(lambda (l) | |
786 (when (apply 'desktop-save-buffer-p l) | |
787 (insert "(" | |
788 (if (or (not (integerp eager)) | |
789 (unless (zerop eager) | |
790 (setq eager (1- eager)) | |
791 t)) | |
792 "desktop-create-buffer" | |
793 "desktop-append-buffer-args") | |
794 " " | |
795 desktop-file-version) | |
796 (mapc #'(lambda (e) | |
797 (insert "\n " (desktop-value-to-string e))) | |
798 l) | |
799 (insert ")\n\n"))) | |
800 info) | |
3404 | 801 (setq default-directory dirname) |
38618
c41fb9fae096
(desktop-save): Bind coding-system-for-write to
Gerd Moellmann <gerd@gnu.org>
parents:
38592
diff
changeset
|
802 (let ((coding-system-for-write 'emacs-mule)) |
88155 | 803 (write-region (point-min) (point-max) filename nil 'nomessage)))) |
3404 | 804 (setq desktop-dirname dirname)) |
88155 | 805 |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
806 ;; ---------------------------------------------------------------------------- |
3404 | 807 (defun desktop-remove () |
88155 | 808 "Delete desktop file in `desktop-dirname'. |
809 This function also sets `desktop-dirname' to nil." | |
3404 | 810 (interactive) |
88155 | 811 (when desktop-dirname |
812 (let ((filename (expand-file-name desktop-base-file-name desktop-dirname))) | |
813 (setq desktop-dirname nil) | |
814 (when (file-exists-p filename) | |
815 (delete-file filename))))) | |
816 | |
817 (defvar desktop-buffer-args-list nil | |
818 "List of args for `desktop-create-buffer'.") | |
819 | |
820 (defvar desktop-lazy-timer nil) | |
821 | |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
822 ;; ---------------------------------------------------------------------------- |
21303
346595905ae4
(desktop-load-default): Add autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
20772
diff
changeset
|
823 ;;;###autoload |
88155 | 824 (defun desktop-read (&optional dirname) |
825 "Read and process the desktop file in directory DIRNAME. | |
826 Look for a desktop file in DIRNAME, or if DIRNAME is omitted, look in | |
827 directories listed in `desktop-path'. If a desktop file is found, it | |
828 is processed and `desktop-after-read-hook' is run. If no desktop file | |
829 is found, clear the desktop and run `desktop-no-desktop-file-hook'. | |
830 This function is a no-op when Emacs is running in batch mode. | |
831 It returns t if a desktop file was loaded, nil otherwise." | |
3404 | 832 (interactive) |
88155 | 833 (unless noninteractive |
834 (setq desktop-dirname | |
835 (file-name-as-directory | |
836 (expand-file-name | |
837 (or | |
838 ;; If DIRNAME is specified, use it. | |
839 (and (< 0 (length dirname)) dirname) | |
840 ;; Otherwise search desktop file in desktop-path. | |
841 (let ((dirs desktop-path)) | |
842 (while | |
843 (and | |
844 dirs | |
845 (not | |
846 (file-exists-p (expand-file-name desktop-base-file-name (car dirs))))) | |
847 (setq dirs (cdr dirs))) | |
848 (and dirs (car dirs))) | |
849 ;; If not found and `desktop-path' is non-nil, use its first element. | |
850 (and desktop-path (car desktop-path)) | |
851 ;; Default: Home directory. | |
852 "~")))) | |
853 (if (file-exists-p (expand-file-name desktop-base-file-name desktop-dirname)) | |
854 ;; Desktop file found, process it. | |
855 (let ((desktop-first-buffer nil) | |
856 (desktop-buffer-ok-count 0) | |
857 (desktop-buffer-fail-count 0)) | |
858 (setq desktop-lazy-timer nil) | |
859 ;; Evaluate desktop buffer. | |
860 (load (expand-file-name desktop-base-file-name desktop-dirname) t t t) | |
861 ;; `desktop-create-buffer' puts buffers at end of the buffer list. | |
862 ;; We want buffers existing prior to evaluating the desktop (and not reused) | |
863 ;; to be placed at the end of the buffer list, so we move them here. | |
864 (mapc 'bury-buffer | |
865 (nreverse (cdr (memq desktop-first-buffer (nreverse (buffer-list)))))) | |
866 (switch-to-buffer (car (buffer-list))) | |
867 (run-hooks 'desktop-delay-hook) | |
868 (setq desktop-delay-hook nil) | |
869 (run-hooks 'desktop-after-read-hook) | |
870 (message "Desktop: %d buffer%s restored%s%s." | |
871 desktop-buffer-ok-count | |
872 (if (= 1 desktop-buffer-ok-count) "" "s") | |
873 (if (< 0 desktop-buffer-fail-count) | |
874 (format ", %d failed to restore" desktop-buffer-fail-count) | |
875 "") | |
876 (if desktop-buffer-args-list | |
877 (format ", %d to restore lazily" | |
878 (length desktop-buffer-args-list)) | |
879 "")) | |
880 t) | |
881 ;; No desktop file found. | |
882 (desktop-clear) | |
883 (let ((default-directory desktop-dirname)) | |
884 (run-hooks 'desktop-no-desktop-file-hook)) | |
885 (message "No desktop file.") | |
886 nil))) | |
887 | |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
888 ;; ---------------------------------------------------------------------------- |
88155 | 889 ;; Maintained for backward compatibility |
21303
346595905ae4
(desktop-load-default): Add autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
20772
diff
changeset
|
890 ;;;###autoload |
3404 | 891 (defun desktop-load-default () |
10595 | 892 "Load the `default' start-up library manually. |
88155 | 893 Also inhibit further loading of it." |
894 (unless inhibit-default-init ; safety check | |
895 (load "default" t t) | |
896 (setq inhibit-default-init t))) | |
897 (make-obsolete 'desktop-load-default | |
898 'desktop-save-mode "22.1") | |
899 | |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
900 ;; ---------------------------------------------------------------------------- |
88155 | 901 ;;;###autoload |
902 (defun desktop-change-dir (dirname) | |
903 "Change to desktop saved in DIRNAME. | |
904 Kill the desktop as specified by variables `desktop-save-mode' and | |
905 `desktop-save', then clear the desktop and load the desktop file in | |
906 directory DIRNAME." | |
907 (interactive "DChange to directory: ") | |
908 (setq dirname (file-name-as-directory (expand-file-name dirname desktop-dirname))) | |
909 (desktop-kill) | |
910 (desktop-clear) | |
911 (desktop-read dirname)) | |
32447
cfae1c82d702
Added extensible special buffer support to desktop.el. See the
John Wiegley <johnw@newartisans.com>
parents:
32366
diff
changeset
|
912 |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
913 ;; ---------------------------------------------------------------------------- |
88155 | 914 ;;;###autoload |
915 (defun desktop-save-in-desktop-dir () | |
916 "Save the desktop in directory `desktop-dirname'." | |
917 (interactive) | |
918 (if desktop-dirname | |
919 (desktop-save desktop-dirname) | |
920 (call-interactively 'desktop-save)) | |
921 (message "Desktop saved in %s" desktop-dirname)) | |
922 | |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
923 ;; ---------------------------------------------------------------------------- |
88155 | 924 ;;;###autoload |
925 (defun desktop-revert () | |
926 "Revert to the last loaded desktop." | |
927 (interactive) | |
928 (unless desktop-dirname | |
929 (error "Unknown desktop directory")) | |
930 (unless (file-exists-p (expand-file-name desktop-base-file-name desktop-dirname)) | |
931 (error "No desktop file found")) | |
932 (desktop-clear) | |
933 (desktop-read desktop-dirname)) | |
934 | |
5465
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
935 ;; ---------------------------------------------------------------------------- |
88155 | 936 (defun desktop-restore-file-buffer (desktop-buffer-file-name |
937 desktop-buffer-name | |
938 desktop-buffer-misc) | |
939 "Restore a file buffer." | |
940 (eval-when-compile ; Just to silence the byte compiler | |
941 (defvar desktop-buffer-major-mode) | |
942 (defvar desktop-buffer-locals)) | |
14755
3d473ed8c718
Global vars mam, fn, bn renamed.
Richard M. Stallman <rms@gnu.org>
parents:
14754
diff
changeset
|
943 (if desktop-buffer-file-name |
3d473ed8c718
Global vars mam, fn, bn renamed.
Richard M. Stallman <rms@gnu.org>
parents:
14754
diff
changeset
|
944 (if (or (file-exists-p desktop-buffer-file-name) |
88155 | 945 (let ((msg (format "Desktop: File \"%s\" no longer exists." |
946 desktop-buffer-file-name))) | |
947 (if desktop-missing-file-warning | |
948 (y-or-n-p (concat msg " Re-create? ")) | |
949 (message "%s" msg) | |
950 nil))) | |
951 (let* ((auto-insert nil) ; Disable auto insertion | |
952 (coding-system-for-read | |
953 (or coding-system-for-read | |
954 (cdr (assq 'buffer-file-coding-system | |
955 desktop-buffer-locals)))) | |
956 (buf (find-file-noselect desktop-buffer-file-name))) | |
32366
40d8b29df57e
(desktop-modes-not-to-save): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
30853
diff
changeset
|
957 (condition-case nil |
40d8b29df57e
(desktop-modes-not-to-save): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
30853
diff
changeset
|
958 (switch-to-buffer buf) |
43831
7837693f5bac
(desktop-buffer-handlers): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
41150
diff
changeset
|
959 (error (pop-to-buffer buf))) |
88155 | 960 (and (not (eq major-mode desktop-buffer-major-mode)) |
961 (functionp desktop-buffer-major-mode) | |
962 (funcall desktop-buffer-major-mode)) | |
43831
7837693f5bac
(desktop-buffer-handlers): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
41150
diff
changeset
|
963 buf) |
88155 | 964 nil))) |
965 | |
966 (defun desktop-load-file (function) | |
967 "Load the file where auto loaded FUNCTION is defined." | |
968 (when function | |
969 (let ((fcell (symbol-function function))) | |
970 (when (and (listp fcell) | |
971 (eq 'autoload (car fcell))) | |
972 (load (cadr fcell)))))) | |
973 | |
4830
a61307ac474e
Internal clean-up. Save information about current
Richard M. Stallman <rms@gnu.org>
parents:
3405
diff
changeset
|
974 ;; ---------------------------------------------------------------------------- |
88155 | 975 ;; Create a buffer, load its file, set its mode, ...; |
976 ;; called from Desktop file only. | |
40210
01666fd1b210
(desktop-last-buffer): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
38798
diff
changeset
|
977 |
88155 | 978 ;; Just to silence the byte compiler. |
979 (eval-when-compile | |
980 (defvar desktop-first-buffer)) ; Dynamically bound in `desktop-read' | |
40210
01666fd1b210
(desktop-last-buffer): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
38798
diff
changeset
|
981 |
88155 | 982 (defun desktop-create-buffer |
983 (desktop-file-version | |
984 desktop-buffer-file-name | |
985 desktop-buffer-name | |
986 desktop-buffer-major-mode | |
987 desktop-buffer-minor-modes | |
988 desktop-buffer-point | |
989 desktop-buffer-mark | |
990 desktop-buffer-read-only | |
991 desktop-buffer-misc | |
992 &optional | |
993 desktop-buffer-locals) | |
994 ;; Just to silence the byte compiler. Bound locally in `desktop-read'. | |
995 (eval-when-compile | |
996 (defvar desktop-buffer-ok-count) | |
997 (defvar desktop-buffer-fail-count)) | |
998 ;; To make desktop files with relative file names possible, we cannot | |
999 ;; allow `default-directory' to change. Therefore we save current buffer. | |
1000 (save-current-buffer | |
1001 ;; Give major mode module a chance to add a handler. | |
1002 (desktop-load-file desktop-buffer-major-mode) | |
1003 (let ((buffer-list (buffer-list)) | |
1004 (result | |
1005 (condition-case err | |
1006 (funcall (or (cdr (assq desktop-buffer-major-mode | |
1007 desktop-buffer-mode-handlers)) | |
1008 'desktop-restore-file-buffer) | |
1009 desktop-buffer-file-name | |
1010 desktop-buffer-name | |
1011 desktop-buffer-misc) | |
1012 (error | |
1013 (message "Desktop: Can't load buffer %s: %s" | |
1014 desktop-buffer-name | |
1015 (error-message-string err)) | |
1016 (when desktop-missing-file-warning (sit-for 1)) | |
1017 nil)))) | |
1018 (if (bufferp result) | |
1019 (setq desktop-buffer-ok-count (1+ desktop-buffer-ok-count)) | |
1020 (setq desktop-buffer-fail-count (1+ desktop-buffer-fail-count)) | |
1021 (setq result nil)) | |
1022 ;; Restore buffer list order with new buffer at end. Don't change | |
1023 ;; the order for old desktop files (old desktop module behaviour). | |
1024 (unless (< desktop-file-version 206) | |
1025 (mapc 'bury-buffer buffer-list) | |
1026 (when result (bury-buffer result))) | |
1027 (when result | |
1028 (unless (or desktop-first-buffer (< desktop-file-version 206)) | |
1029 (setq desktop-first-buffer result)) | |
1030 (set-buffer result) | |
1031 (unless (equal (buffer-name) desktop-buffer-name) | |
1032 (rename-buffer desktop-buffer-name)) | |
1033 ;; minor modes | |
1034 (cond ((equal '(t) desktop-buffer-minor-modes) ; backwards compatible | |
1035 (auto-fill-mode 1)) | |
1036 ((equal '(nil) desktop-buffer-minor-modes) ; backwards compatible | |
1037 (auto-fill-mode 0)) | |
1038 (t | |
1039 (mapc #'(lambda (minor-mode) | |
1040 ;; Give minor mode module a chance to add a handler. | |
1041 (desktop-load-file minor-mode) | |
1042 (let ((handler (cdr (assq minor-mode desktop-minor-mode-handlers)))) | |
1043 (if handler | |
1044 (funcall handler desktop-buffer-locals) | |
1045 (when (functionp minor-mode) | |
1046 (funcall minor-mode 1))))) | |
1047 desktop-buffer-minor-modes))) | |
1048 ;; Even though point and mark are non-nil when written by `desktop-save', | |
1049 ;; they may be modified by handlers wanting to set point or mark themselves. | |
1050 (when desktop-buffer-point | |
1051 (goto-char | |
1052 (condition-case err | |
1053 ;; Evaluate point. Thus point can be something like '(search-forward ... | |
1054 (eval desktop-buffer-point) | |
1055 (error (message "%s" (error-message-string err)) 1)))) | |
1056 (when desktop-buffer-mark | |
1057 (if (consp desktop-buffer-mark) | |
1058 (progn | |
1059 (set-mark (car desktop-buffer-mark)) | |
1060 (setq mark-active (car (cdr desktop-buffer-mark)))) | |
1061 (set-mark desktop-buffer-mark))) | |
1062 ;; Never override file system if the file really is read-only marked. | |
1063 (if desktop-buffer-read-only (setq buffer-read-only desktop-buffer-read-only)) | |
1064 (while desktop-buffer-locals | |
1065 (let ((this (car desktop-buffer-locals))) | |
1066 (if (consp this) | |
1067 ;; an entry of this form `(symbol . value)' | |
1068 (progn | |
1069 (make-local-variable (car this)) | |
1070 (set (car this) (cdr this))) | |
1071 ;; an entry of the form `symbol' | |
1072 (make-local-variable this) | |
1073 (makunbound this))) | |
1074 (setq desktop-buffer-locals (cdr desktop-buffer-locals))))))) | |
5465
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
1075 |
88155 | 1076 ;; ---------------------------------------------------------------------------- |
5465
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
1077 ;; Backward compatibility -- update parameters to 205 standards. |
14755
3d473ed8c718
Global vars mam, fn, bn renamed.
Richard M. Stallman <rms@gnu.org>
parents:
14754
diff
changeset
|
1078 (defun desktop-buffer (desktop-buffer-file-name desktop-buffer-name |
3d473ed8c718
Global vars mam, fn, bn renamed.
Richard M. Stallman <rms@gnu.org>
parents:
14754
diff
changeset
|
1079 desktop-buffer-major-mode |
14756
aabf776c3b6a
Global var `misc' renamed.
Richard M. Stallman <rms@gnu.org>
parents:
14755
diff
changeset
|
1080 mim pt mk ro tl fc cfs cr desktop-buffer-misc) |
14755
3d473ed8c718
Global vars mam, fn, bn renamed.
Richard M. Stallman <rms@gnu.org>
parents:
14754
diff
changeset
|
1081 (desktop-create-buffer 205 desktop-buffer-file-name desktop-buffer-name |
14756
aabf776c3b6a
Global var `misc' renamed.
Richard M. Stallman <rms@gnu.org>
parents:
14755
diff
changeset
|
1082 desktop-buffer-major-mode (cdr mim) pt mk ro |
aabf776c3b6a
Global var `misc' renamed.
Richard M. Stallman <rms@gnu.org>
parents:
14755
diff
changeset
|
1083 desktop-buffer-misc |
5465
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
1084 (list (cons 'truncate-lines tl) |
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
1085 (cons 'fill-column fc) |
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
1086 (cons 'case-fold-search cfs) |
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
1087 (cons 'case-replace cr) |
9fcfca1caec7
(desktop-buffer-mh): New function for mh mail system.
Richard M. Stallman <rms@gnu.org>
parents:
5314
diff
changeset
|
1088 (cons 'overwrite-mode (car mim))))) |
88155 | 1089 |
1090 (defun desktop-append-buffer-args (&rest args) | |
1091 "Append ARGS at end of `desktop-buffer-args-list'. | |
1092 ARGS must be an argument list for `desktop-create-buffer'." | |
1093 (setq desktop-buffer-args-list (nconc desktop-buffer-args-list (list args))) | |
1094 (unless desktop-lazy-timer | |
1095 (setq desktop-lazy-timer | |
1096 (run-with-idle-timer desktop-lazy-idle-delay t 'desktop-idle-create-buffers)))) | |
1097 | |
1098 (defun desktop-lazy-create-buffer () | |
1099 "Pop args from `desktop-buffer-args-list', create buffer and bury it." | |
1100 (when desktop-buffer-args-list | |
1101 (let* ((remaining (length desktop-buffer-args-list)) | |
1102 (args (pop desktop-buffer-args-list)) | |
1103 (buffer-name (nth 2 args)) | |
1104 (msg (format "Desktop lazily opening %s (%s remaining)..." | |
1105 buffer-name remaining))) | |
1106 (when desktop-lazy-verbose | |
1107 (message "%s" msg)) | |
1108 (let ((desktop-first-buffer nil) | |
1109 (desktop-buffer-ok-count 0) | |
1110 (desktop-buffer-fail-count 0)) | |
1111 (apply 'desktop-create-buffer args) | |
1112 (run-hooks 'desktop-delay-hook) | |
1113 (setq desktop-delay-hook nil) | |
1114 (bury-buffer (get-buffer buffer-name)) | |
1115 (when desktop-lazy-verbose | |
1116 (message "%s%s" msg (if (> desktop-buffer-ok-count 0) "done" "failed"))))))) | |
20526
ec0a8ccddd6c
(desktop-enable): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18581
diff
changeset
|
1117 |
88155 | 1118 (defun desktop-idle-create-buffers () |
1119 "Create buffers until the user does something, then stop. | |
1120 If there are no buffers left to create, kill the timer." | |
1121 (let ((repeat 1)) | |
1122 (while (and repeat desktop-buffer-args-list) | |
1123 (save-window-excursion | |
1124 (desktop-lazy-create-buffer)) | |
1125 (setq repeat (sit-for 0.2)) | |
1126 (unless desktop-buffer-args-list | |
1127 (cancel-timer desktop-lazy-timer) | |
1128 (setq desktop-lazy-timer nil) | |
1129 (message "Lazy desktop load complete") | |
1130 (sit-for 3) | |
1131 (message ""))))) | |
1132 | |
1133 (defun desktop-lazy-complete () | |
1134 "Run the desktop load to completion." | |
1135 (interactive) | |
1136 (let ((desktop-lazy-verbose t)) | |
1137 (while desktop-buffer-args-list | |
1138 (save-window-excursion | |
1139 (desktop-lazy-create-buffer))) | |
1140 (message "Lazy desktop load complete"))) | |
1141 | |
1142 (defun desktop-lazy-abort () | |
1143 "Abort lazy loading of the desktop." | |
1144 (interactive) | |
1145 (when desktop-lazy-timer | |
1146 (cancel-timer desktop-lazy-timer) | |
1147 (setq desktop-lazy-timer nil)) | |
1148 (when desktop-buffer-args-list | |
1149 (setq desktop-buffer-args-list nil) | |
1150 (when (interactive-p) | |
1151 (message "Lazy desktop load aborted")))) | |
1152 | |
1153 ;; ---------------------------------------------------------------------------- | |
1154 ;; When `desktop-save-mode' is non-nil and "--no-desktop" is not specified on the | |
1155 ;; command line, we do the rest of what it takes to use desktop, but do it | |
1156 ;; after finishing loading the init file. | |
1157 ;; We cannot use `command-switch-alist' to process "--no-desktop" because these | |
1158 ;; functions are processed after `after-init-hook'. | |
1159 (add-hook | |
1160 'after-init-hook | |
1161 '(lambda () | |
1162 (let ((key "--no-desktop")) | |
1163 (when (member key command-line-args) | |
1164 (setq command-line-args (delete key command-line-args)) | |
1165 (setq desktop-save-mode nil))) | |
1166 (when desktop-save-mode (desktop-read)))) | |
20526
ec0a8ccddd6c
(desktop-enable): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18581
diff
changeset
|
1167 |
3405 | 1168 (provide 'desktop) |
3404 | 1169 |
88155 | 1170 ;;; arch-tag: 221907c3-1771-4fd3-9c2e-c6f700c6ede9 |
32366
40d8b29df57e
(desktop-modes-not-to-save): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
30853
diff
changeset
|
1171 ;;; desktop.el ends here |