Mercurial > emacs
annotate lisp/cus-edit.el @ 28923:dcafe3c9cd6c
(sh-while-getopts) <sh>: Handle case that
user-specified option string is empty.
| author | Gerd Moellmann <gerd@gnu.org> |
|---|---|
| date | Mon, 15 May 2000 20:14:39 +0000 |
| parents | e9fb71a3e51d |
| children | 54b181bf04dc |
| rev | line source |
|---|---|
| 28130 | 1 ;;; cus-edit.el --- Tools for customizing Emacs and Lisp packages. |
| 17334 | 2 ;; |
|
27250
807fc106b24c
(custom-hook-convert-widget): Fix comment.
Gerd Moellmann <gerd@gnu.org>
parents:
26803
diff
changeset
|
3 ;; Copyright (C) 1996, 1997, 1999, 2000 Free Software Foundation, Inc. |
| 17334 | 4 ;; |
| 5 ;; Author: Per Abrahamsen <abraham@dina.kvl.dk> | |
| 6 ;; Keywords: help, faces | |
| 7 | |
|
17521
ddce9ecc6f6a
(custom-face-set): Don't copy an empty face,
Richard M. Stallman <rms@gnu.org>
parents:
17415
diff
changeset
|
8 ;; This file is part of GNU Emacs. |
|
ddce9ecc6f6a
(custom-face-set): Don't copy an empty face,
Richard M. Stallman <rms@gnu.org>
parents:
17415
diff
changeset
|
9 |
|
ddce9ecc6f6a
(custom-face-set): Don't copy an empty face,
Richard M. Stallman <rms@gnu.org>
parents:
17415
diff
changeset
|
10 ;; GNU Emacs is free software; you can redistribute it and/or modify |
|
ddce9ecc6f6a
(custom-face-set): Don't copy an empty face,
Richard M. Stallman <rms@gnu.org>
parents:
17415
diff
changeset
|
11 ;; it under the terms of the GNU General Public License as published by |
|
ddce9ecc6f6a
(custom-face-set): Don't copy an empty face,
Richard M. Stallman <rms@gnu.org>
parents:
17415
diff
changeset
|
12 ;; the Free Software Foundation; either version 2, or (at your option) |
|
ddce9ecc6f6a
(custom-face-set): Don't copy an empty face,
Richard M. Stallman <rms@gnu.org>
parents:
17415
diff
changeset
|
13 ;; any later version. |
|
ddce9ecc6f6a
(custom-face-set): Don't copy an empty face,
Richard M. Stallman <rms@gnu.org>
parents:
17415
diff
changeset
|
14 |
|
ddce9ecc6f6a
(custom-face-set): Don't copy an empty face,
Richard M. Stallman <rms@gnu.org>
parents:
17415
diff
changeset
|
15 ;; GNU Emacs is distributed in the hope that it will be useful, |
|
ddce9ecc6f6a
(custom-face-set): Don't copy an empty face,
Richard M. Stallman <rms@gnu.org>
parents:
17415
diff
changeset
|
16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
ddce9ecc6f6a
(custom-face-set): Don't copy an empty face,
Richard M. Stallman <rms@gnu.org>
parents:
17415
diff
changeset
|
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
ddce9ecc6f6a
(custom-face-set): Don't copy an empty face,
Richard M. Stallman <rms@gnu.org>
parents:
17415
diff
changeset
|
18 ;; GNU General Public License for more details. |
|
ddce9ecc6f6a
(custom-face-set): Don't copy an empty face,
Richard M. Stallman <rms@gnu.org>
parents:
17415
diff
changeset
|
19 |
|
ddce9ecc6f6a
(custom-face-set): Don't copy an empty face,
Richard M. Stallman <rms@gnu.org>
parents:
17415
diff
changeset
|
20 ;; You should have received a copy of the GNU General Public License |
|
ddce9ecc6f6a
(custom-face-set): Don't copy an empty face,
Richard M. Stallman <rms@gnu.org>
parents:
17415
diff
changeset
|
21 ;; along with GNU Emacs; see the file COPYING. If not, write to the |
|
ddce9ecc6f6a
(custom-face-set): Don't copy an empty face,
Richard M. Stallman <rms@gnu.org>
parents:
17415
diff
changeset
|
22 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
|
ddce9ecc6f6a
(custom-face-set): Don't copy an empty face,
Richard M. Stallman <rms@gnu.org>
parents:
17415
diff
changeset
|
23 ;; Boston, MA 02111-1307, USA. |
|
ddce9ecc6f6a
(custom-face-set): Don't copy an empty face,
Richard M. Stallman <rms@gnu.org>
parents:
17415
diff
changeset
|
24 |
| 17334 | 25 ;;; Commentary: |
| 26 ;; | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
27 ;; This file implements the code to create and edit customize buffers. |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
28 ;; |
| 17334 | 29 ;; See `custom.el'. |
| 30 | |
|
18435
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
31 ;; No commands should have names starting with `custom-' because |
|
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
32 ;; that interferes with completion. Use `customize-' for commands |
|
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
33 ;; that the user will run with M-x, and `Custom-' for interactive commands. |
|
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
34 |
| 17334 | 35 ;;; Code: |
| 36 | |
| 37 (require 'cus-face) | |
| 38 (require 'wid-edit) | |
| 39 (require 'easymenu) | |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
40 (eval-when-compile |
|
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
41 (require 'cl) |
|
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
42 (defvar custom-versions-load-alist)) ; from cus-load |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
43 |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
44 (condition-case nil |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
45 (require 'cus-load) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
46 (error nil)) |
| 17334 | 47 |
| 18089 | 48 (condition-case nil |
| 49 (require 'cus-start) | |
| 50 (error nil)) | |
| 51 | |
| 17415 | 52 (put 'custom-define-hook 'custom-type 'hook) |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
53 (put 'custom-define-hook 'standard-value '(nil)) |
| 17415 | 54 (custom-add-to-group 'customize 'custom-define-hook 'custom-variable) |
| 55 | |
| 17334 | 56 ;;; Customization Groups. |
| 57 | |
| 58 (defgroup emacs nil | |
| 59 "Customization of the One True Editor." | |
| 60 :link '(custom-manual "(emacs)Top")) | |
| 61 | |
| 62 ;; Most of these groups are stolen from `finder.el', | |
| 63 (defgroup editing nil | |
| 64 "Basic text editing facilities." | |
| 65 :group 'emacs) | |
| 66 | |
| 67 (defgroup abbrev nil | |
| 68 "Abbreviation handling, typing shortcuts, macros." | |
| 69 :tag "Abbreviations" | |
| 70 :group 'editing) | |
| 71 | |
| 72 (defgroup matching nil | |
| 73 "Various sorts of searching and matching." | |
| 74 :group 'editing) | |
| 75 | |
| 76 (defgroup emulations nil | |
| 77 "Emulations of other editors." | |
| 78 :group 'editing) | |
| 79 | |
| 80 (defgroup mouse nil | |
| 81 "Mouse support." | |
| 82 :group 'editing) | |
| 83 | |
| 84 (defgroup outlines nil | |
| 85 "Support for hierarchical outlining." | |
| 86 :group 'editing) | |
| 87 | |
| 88 (defgroup external nil | |
| 89 "Interfacing to external utilities." | |
| 90 :group 'emacs) | |
| 91 | |
| 92 (defgroup bib nil | |
| 93 "Code related to the `bib' bibliography processor." | |
| 94 :tag "Bibliography" | |
| 95 :group 'external) | |
| 96 | |
| 97 (defgroup processes nil | |
| 98 "Process, subshell, compilation, and job control support." | |
| 99 :group 'external | |
| 100 :group 'development) | |
| 101 | |
|
22068
82db88d21acd
(convenience): New group.
Richard M. Stallman <rms@gnu.org>
parents:
22001
diff
changeset
|
102 (defgroup convenience nil |
|
82db88d21acd
(convenience): New group.
Richard M. Stallman <rms@gnu.org>
parents:
22001
diff
changeset
|
103 "Convenience features for faster editing." |
|
82db88d21acd
(convenience): New group.
Richard M. Stallman <rms@gnu.org>
parents:
22001
diff
changeset
|
104 :group 'emacs) |
|
82db88d21acd
(convenience): New group.
Richard M. Stallman <rms@gnu.org>
parents:
22001
diff
changeset
|
105 |
| 17334 | 106 (defgroup programming nil |
| 107 "Support for programming in other languages." | |
| 108 :group 'emacs) | |
| 109 | |
| 110 (defgroup languages nil | |
| 111 "Specialized modes for editing programming languages." | |
| 112 :group 'programming) | |
| 113 | |
| 114 (defgroup lisp nil | |
| 115 "Lisp support, including Emacs Lisp." | |
| 116 :group 'languages | |
| 117 :group 'development) | |
| 118 | |
| 119 (defgroup c nil | |
| 120 "Support for the C language and related languages." | |
| 121 :group 'languages) | |
| 122 | |
| 123 (defgroup tools nil | |
| 124 "Programming tools." | |
| 125 :group 'programming) | |
| 126 | |
| 127 (defgroup oop nil | |
| 128 "Support for object-oriented programming." | |
| 129 :group 'programming) | |
| 130 | |
| 131 (defgroup applications nil | |
| 132 "Applications written in Emacs." | |
| 133 :group 'emacs) | |
| 134 | |
| 135 (defgroup calendar nil | |
| 136 "Calendar and time management support." | |
| 137 :group 'applications) | |
| 138 | |
| 139 (defgroup mail nil | |
| 140 "Modes for electronic-mail handling." | |
| 141 :group 'applications) | |
| 142 | |
| 143 (defgroup news nil | |
| 144 "Support for netnews reading and posting." | |
| 145 :group 'applications) | |
| 146 | |
| 147 (defgroup games nil | |
| 148 "Games, jokes and amusements." | |
| 149 :group 'applications) | |
| 150 | |
| 151 (defgroup development nil | |
| 152 "Support for further development of Emacs." | |
| 153 :group 'emacs) | |
| 154 | |
| 155 (defgroup docs nil | |
| 156 "Support for Emacs documentation." | |
| 157 :group 'development) | |
| 158 | |
| 159 (defgroup extensions nil | |
| 160 "Emacs Lisp language extensions." | |
| 161 :group 'development) | |
| 162 | |
| 163 (defgroup internal nil | |
| 164 "Code for Emacs internals, build process, defaults." | |
| 165 :group 'development) | |
| 166 | |
| 167 (defgroup maint nil | |
| 168 "Maintenance aids for the Emacs development group." | |
| 169 :tag "Maintenance" | |
| 170 :group 'development) | |
| 171 | |
| 172 (defgroup environment nil | |
| 173 "Fitting Emacs with its environment." | |
| 174 :group 'emacs) | |
| 175 | |
| 176 (defgroup comm nil | |
| 177 "Communications, networking, remote access to files." | |
| 178 :tag "Communication" | |
| 179 :group 'environment) | |
| 180 | |
| 181 (defgroup hardware nil | |
| 182 "Support for interfacing with exotic hardware." | |
| 183 :group 'environment) | |
| 184 | |
| 185 (defgroup terminals nil | |
| 186 "Support for terminal types." | |
| 187 :group 'environment) | |
| 188 | |
| 189 (defgroup unix nil | |
| 190 "Front-ends/assistants for, or emulators of, UNIX features." | |
| 191 :group 'environment) | |
| 192 | |
| 193 (defgroup vms nil | |
| 194 "Support code for vms." | |
| 195 :group 'environment) | |
| 196 | |
| 197 (defgroup i18n nil | |
| 198 "Internationalization and alternate character-set support." | |
| 199 :group 'environment | |
| 200 :group 'editing) | |
| 201 | |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
202 (defgroup x nil |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
203 "The X Window system." |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
204 :group 'environment) |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
205 |
| 17334 | 206 (defgroup frames nil |
| 207 "Support for Emacs frames and window systems." | |
| 208 :group 'environment) | |
| 209 | |
| 210 (defgroup data nil | |
| 211 "Support editing files of data." | |
| 212 :group 'emacs) | |
| 213 | |
|
18320
bb83860447d0
(files): New group `files'.
Richard M. Stallman <rms@gnu.org>
parents:
18258
diff
changeset
|
214 (defgroup files nil |
|
bb83860447d0
(files): New group `files'.
Richard M. Stallman <rms@gnu.org>
parents:
18258
diff
changeset
|
215 "Support editing files." |
|
bb83860447d0
(files): New group `files'.
Richard M. Stallman <rms@gnu.org>
parents:
18258
diff
changeset
|
216 :group 'emacs) |
|
bb83860447d0
(files): New group `files'.
Richard M. Stallman <rms@gnu.org>
parents:
18258
diff
changeset
|
217 |
| 17334 | 218 (defgroup wp nil |
| 219 "Word processing." | |
| 220 :group 'emacs) | |
| 221 | |
| 222 (defgroup tex nil | |
| 223 "Code related to the TeX formatter." | |
| 224 :group 'wp) | |
| 225 | |
| 226 (defgroup faces nil | |
| 227 "Support for multiple fonts." | |
| 228 :group 'emacs) | |
| 229 | |
| 230 (defgroup hypermedia nil | |
| 231 "Support for links between text or other media types." | |
| 232 :group 'emacs) | |
| 233 | |
| 234 (defgroup help nil | |
| 235 "Support for on-line help systems." | |
| 236 :group 'emacs) | |
| 237 | |
| 25685 | 238 (defgroup multimedia nil |
| 239 "Non-textual support, specifically images and sound." | |
| 240 :group 'emacs) | |
| 241 | |
| 17334 | 242 (defgroup local nil |
| 243 "Code local to your site." | |
| 244 :group 'emacs) | |
| 245 | |
| 246 (defgroup customize '((widgets custom-group)) | |
| 247 "Customization of the Customization support." | |
|
23357
856a82c440fa
(Custom-mode-menu): Fix info node name.
Karl Heuer <kwzh@gnu.org>
parents:
23223
diff
changeset
|
248 :link '(custom-manual "(elisp)Customization") |
| 25685 | 249 :link '(url-link :tag "(Old?) Development Page" |
| 17334 | 250 "http://www.dina.kvl.dk/~abraham/custom/") |
| 251 :prefix "custom-" | |
| 17415 | 252 :group 'help) |
| 253 | |
| 254 (defgroup custom-faces nil | |
| 255 "Faces used by customize." | |
| 256 :group 'customize | |
| 17334 | 257 :group 'faces) |
| 258 | |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
259 (defgroup custom-browse nil |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
260 "Control customize browser." |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
261 :prefix "custom-" |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
262 :group 'customize) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
263 |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
264 (defgroup custom-buffer nil |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
265 "Control customize buffers." |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
266 :prefix "custom-" |
|
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
267 :group 'customize) |
|
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
268 |
|
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
269 (defgroup custom-menu nil |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
270 "Control customize menus." |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
271 :prefix "custom-" |
|
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
272 :group 'customize) |
|
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
273 |
| 17415 | 274 (defgroup abbrev-mode nil |
| 275 "Word abbreviations mode." | |
| 276 :group 'abbrev) | |
| 277 | |
| 278 (defgroup alloc nil | |
| 279 "Storage allocation and gc for GNU Emacs Lisp interpreter." | |
| 280 :tag "Storage Allocation" | |
| 281 :group 'internal) | |
| 282 | |
| 283 (defgroup undo nil | |
| 284 "Undoing changes in buffers." | |
| 285 :group 'editing) | |
| 286 | |
| 287 (defgroup modeline nil | |
| 288 "Content of the modeline." | |
| 289 :group 'environment) | |
| 290 | |
| 291 (defgroup fill nil | |
| 292 "Indenting and filling text." | |
| 293 :group 'editing) | |
| 294 | |
| 295 (defgroup editing-basics nil | |
| 296 "Most basic editing facilities." | |
| 297 :group 'editing) | |
| 298 | |
| 299 (defgroup display nil | |
| 300 "How characters are displayed in buffers." | |
| 301 :group 'environment) | |
| 302 | |
| 303 (defgroup execute nil | |
| 304 "Executing external commands." | |
| 305 :group 'processes) | |
| 306 | |
| 307 (defgroup installation nil | |
| 308 "The Emacs installation." | |
| 309 :group 'environment) | |
| 310 | |
| 311 (defgroup dired nil | |
| 312 "Directory editing." | |
| 313 :group 'environment) | |
| 314 | |
| 315 (defgroup limits nil | |
| 316 "Internal Emacs limits." | |
| 317 :group 'internal) | |
| 318 | |
| 319 (defgroup debug nil | |
| 320 "Debugging Emacs itself." | |
| 321 :group 'development) | |
| 322 | |
| 323 (defgroup minibuffer nil | |
| 324 "Controling the behaviour of the minibuffer." | |
| 325 :group 'environment) | |
| 326 | |
| 327 (defgroup keyboard nil | |
| 328 "Input from the keyboard." | |
| 329 :group 'environment) | |
| 330 | |
| 331 (defgroup mouse nil | |
| 332 "Input from the mouse." | |
| 333 :group 'environment) | |
| 334 | |
| 335 (defgroup menu nil | |
| 336 "Input from the menus." | |
| 337 :group 'environment) | |
| 338 | |
| 339 (defgroup auto-save nil | |
| 340 "Preventing accidential loss of data." | |
|
18320
bb83860447d0
(files): New group `files'.
Richard M. Stallman <rms@gnu.org>
parents:
18258
diff
changeset
|
341 :group 'files) |
| 17415 | 342 |
| 343 (defgroup processes-basics nil | |
| 344 "Basic stuff dealing with processes." | |
| 345 :group 'processes) | |
| 346 | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
347 (defgroup mule nil |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
348 "MULE Emacs internationalization." |
|
18053
941f5d1a241e
(cus-start): Require cus-start.
Richard M. Stallman <rms@gnu.org>
parents:
18033
diff
changeset
|
349 :group 'i18n) |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
350 |
| 17415 | 351 (defgroup windows nil |
| 352 "Windows within a frame." | |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
353 :group 'environment) |
| 17415 | 354 |
| 17334 | 355 ;;; Utilities. |
| 356 | |
| 357 (defun custom-quote (sexp) | |
| 358 "Quote SEXP iff it is not self quoting." | |
| 359 (if (or (memq sexp '(t nil)) | |
| 28130 | 360 (keywordp sexp) |
| 17334 | 361 (and (listp sexp) |
| 362 (memq (car sexp) '(lambda))) | |
| 363 (stringp sexp) | |
| 364 (numberp sexp) | |
| 25685 | 365 (vectorp sexp) |
| 366 ;;; (and (fboundp 'characterp) | |
| 367 ;;; (characterp sexp)) | |
| 368 ) | |
| 17334 | 369 sexp |
| 370 (list 'quote sexp))) | |
| 371 | |
| 372 (defun custom-split-regexp-maybe (regexp) | |
| 373 "If REGEXP is a string, split it to a list at `\\|'. | |
| 25685 | 374 You can get the original back with from the result with: |
| 17334 | 375 (mapconcat 'identity result \"\\|\") |
| 376 | |
| 377 IF REGEXP is not a string, return it unchanged." | |
| 378 (if (stringp regexp) | |
| 379 (let ((start 0) | |
| 380 all) | |
| 381 (while (string-match "\\\\|" regexp start) | |
| 382 (setq all (cons (substring regexp start (match-beginning 0)) all) | |
| 383 start (match-end 0))) | |
| 384 (nreverse (cons (substring regexp start) all))) | |
| 385 regexp)) | |
| 386 | |
| 17415 | 387 (defun custom-variable-prompt () |
| 388 ;; Code stolen from `help.el'. | |
| 389 "Prompt for a variable, defaulting to the variable at point. | |
| 390 Return a list suitable for use in `interactive'." | |
| 391 (let ((v (variable-at-point)) | |
| 392 (enable-recursive-minibuffers t) | |
| 393 val) | |
| 25685 | 394 (setq val (completing-read |
|
18085
3da4eaba1fe8
(custom-variable-prompt): Handle variable-at-point returning 0.
Richard M. Stallman <rms@gnu.org>
parents:
18067
diff
changeset
|
395 (if (symbolp v) |
|
18131
5711f2e5a643
(custom-variable-prompt): Change prompt.
Richard M. Stallman <rms@gnu.org>
parents:
18090
diff
changeset
|
396 (format "Customize option: (default %s) " v) |
| 17415 | 397 "Customize variable: ") |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
398 obarray (lambda (symbol) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
399 (and (boundp symbol) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
400 (or (get symbol 'custom-type) |
|
24509
3cb266497eb3
(custom-variable-prompt): Allow customization of
Karl Heuer <kwzh@gnu.org>
parents:
24030
diff
changeset
|
401 (get symbol 'custom-loads) |
|
20397
a7bab1d0c5e3
(custom-variable-prompt): Ensure valid variable name
Karl Heuer <kwzh@gnu.org>
parents:
20262
diff
changeset
|
402 (user-variable-p symbol)))) t)) |
| 17415 | 403 (list (if (equal val "") |
|
18085
3da4eaba1fe8
(custom-variable-prompt): Handle variable-at-point returning 0.
Richard M. Stallman <rms@gnu.org>
parents:
18067
diff
changeset
|
404 (if (symbolp v) v nil) |
|
3da4eaba1fe8
(custom-variable-prompt): Handle variable-at-point returning 0.
Richard M. Stallman <rms@gnu.org>
parents:
18067
diff
changeset
|
405 (intern val))))) |
| 17415 | 406 |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
407 (defun custom-menu-filter (menu widget) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
408 "Convert MENU to the form used by `widget-choose'. |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
409 MENU should be in the same format as `custom-variable-menu'. |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
410 WIDGET is the widget to apply the filter entries of MENU on." |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
411 (let ((result nil) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
412 current name action filter) |
| 25685 | 413 (while menu |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
414 (setq current (car menu) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
415 name (nth 0 current) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
416 action (nth 1 current) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
417 filter (nth 2 current) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
418 menu (cdr menu)) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
419 (if (or (null filter) (funcall filter widget)) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
420 (push (cons name action) result) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
421 (push name result))) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
422 (nreverse result))) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
423 |
| 17415 | 424 ;;; Unlispify. |
| 425 | |
| 17334 | 426 (defvar custom-prefix-list nil |
| 28130 | 427 "List of prefixes that should be ignored by `custom-unlispify'.") |
| 17334 | 428 |
| 429 (defcustom custom-unlispify-menu-entries t | |
| 430 "Display menu entries as words instead of symbols if non nil." | |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
431 :group 'custom-menu |
| 17334 | 432 :type 'boolean) |
| 433 | |
|
18812
82c80b23fa9d
(custom-unlispify-remove-prefixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18669
diff
changeset
|
434 (defcustom custom-unlispify-remove-prefixes nil |
|
82c80b23fa9d
(custom-unlispify-remove-prefixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18669
diff
changeset
|
435 "Non-nil means remove group prefixes from option names in buffer." |
|
82c80b23fa9d
(custom-unlispify-remove-prefixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18669
diff
changeset
|
436 :group 'custom-menu |
|
82c80b23fa9d
(custom-unlispify-remove-prefixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18669
diff
changeset
|
437 :type 'boolean) |
|
82c80b23fa9d
(custom-unlispify-remove-prefixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18669
diff
changeset
|
438 |
| 17334 | 439 (defun custom-unlispify-menu-entry (symbol &optional no-suffix) |
| 28130 | 440 "Convert SYMBOL into a menu entry." |
| 17334 | 441 (cond ((not custom-unlispify-menu-entries) |
| 442 (symbol-name symbol)) | |
| 443 ((get symbol 'custom-tag) | |
| 444 (if no-suffix | |
| 445 (get symbol 'custom-tag) | |
| 446 (concat (get symbol 'custom-tag) "..."))) | |
| 447 (t | |
| 448 (save-excursion | |
| 449 (set-buffer (get-buffer-create " *Custom-Work*")) | |
| 450 (erase-buffer) | |
| 451 (princ symbol (current-buffer)) | |
| 452 (goto-char (point-min)) | |
| 17415 | 453 (when (and (eq (get symbol 'custom-type) 'boolean) |
| 454 (re-search-forward "-p\\'" nil t)) | |
| 455 (replace-match "" t t) | |
| 456 (goto-char (point-min))) | |
|
18812
82c80b23fa9d
(custom-unlispify-remove-prefixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18669
diff
changeset
|
457 (if custom-unlispify-remove-prefixes |
|
82c80b23fa9d
(custom-unlispify-remove-prefixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18669
diff
changeset
|
458 (let ((prefixes custom-prefix-list) |
|
82c80b23fa9d
(custom-unlispify-remove-prefixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18669
diff
changeset
|
459 prefix) |
|
82c80b23fa9d
(custom-unlispify-remove-prefixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18669
diff
changeset
|
460 (while prefixes |
|
82c80b23fa9d
(custom-unlispify-remove-prefixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18669
diff
changeset
|
461 (setq prefix (car prefixes)) |
|
82c80b23fa9d
(custom-unlispify-remove-prefixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18669
diff
changeset
|
462 (if (search-forward prefix (+ (point) (length prefix)) t) |
| 25685 | 463 (progn |
|
18812
82c80b23fa9d
(custom-unlispify-remove-prefixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18669
diff
changeset
|
464 (setq prefixes nil) |
|
82c80b23fa9d
(custom-unlispify-remove-prefixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18669
diff
changeset
|
465 (delete-region (point-min) (point))) |
|
82c80b23fa9d
(custom-unlispify-remove-prefixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18669
diff
changeset
|
466 (setq prefixes (cdr prefixes)))))) |
| 17334 | 467 (subst-char-in-region (point-min) (point-max) ?- ?\ t) |
| 468 (capitalize-region (point-min) (point-max)) | |
| 25685 | 469 (unless no-suffix |
| 17334 | 470 (goto-char (point-max)) |
| 471 (insert "...")) | |
| 472 (buffer-string))))) | |
| 473 | |
| 474 (defcustom custom-unlispify-tag-names t | |
| 475 "Display tag names as words instead of symbols if non nil." | |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
476 :group 'custom-buffer |
| 17334 | 477 :type 'boolean) |
| 478 | |
| 479 (defun custom-unlispify-tag-name (symbol) | |
| 28130 | 480 "Convert SYMBOL into a menu entry." |
| 17334 | 481 (let ((custom-unlispify-menu-entries custom-unlispify-tag-names)) |
| 482 (custom-unlispify-menu-entry symbol t))) | |
| 483 | |
| 484 (defun custom-prefix-add (symbol prefixes) | |
| 28130 | 485 "Add SYMBOL to list of ignored PREFIXES." |
| 17334 | 486 (cons (or (get symbol 'custom-prefix) |
| 487 (concat (symbol-name symbol) "-")) | |
| 488 prefixes)) | |
| 489 | |
| 17415 | 490 ;;; Guess. |
| 491 | |
| 492 (defcustom custom-guess-name-alist | |
| 493 '(("-p\\'" boolean) | |
| 494 ("-hook\\'" hook) | |
| 495 ("-face\\'" face) | |
| 496 ("-file\\'" file) | |
| 497 ("-function\\'" function) | |
| 498 ("-functions\\'" (repeat function)) | |
| 499 ("-list\\'" (repeat sexp)) | |
| 500 ("-alist\\'" (repeat (cons sexp sexp)))) | |
| 501 "Alist of (MATCH TYPE). | |
| 502 | |
| 25685 | 503 MATCH should be a regexp matching the name of a symbol, and TYPE should |
| 17415 | 504 be a widget suitable for editing the value of that symbol. The TYPE |
| 505 of the first entry where MATCH matches the name of the symbol will be | |
| 25685 | 506 used. |
| 17415 | 507 |
| 508 This is used for guessing the type of variables not declared with | |
| 509 customize." | |
| 510 :type '(repeat (group (regexp :tag "Match") (sexp :tag "Type"))) | |
| 511 :group 'customize) | |
| 512 | |
| 513 (defcustom custom-guess-doc-alist | |
| 514 '(("\\`\\*?Non-nil " boolean)) | |
| 515 "Alist of (MATCH TYPE). | |
| 516 | |
| 517 MATCH should be a regexp matching a documentation string, and TYPE | |
| 518 should be a widget suitable for editing the value of a variable with | |
| 519 that documentation string. The TYPE of the first entry where MATCH | |
| 520 matches the name of the symbol will be used. | |
| 521 | |
| 522 This is used for guessing the type of variables not declared with | |
| 523 customize." | |
| 524 :type '(repeat (group (regexp :tag "Match") (sexp :tag "Type"))) | |
| 525 :group 'customize) | |
| 526 | |
| 527 (defun custom-guess-type (symbol) | |
| 528 "Guess a widget suitable for editing the value of SYMBOL. | |
| 25685 | 529 This is done by matching SYMBOL with `custom-guess-name-alist' and |
| 17415 | 530 if that fails, the doc string with `custom-guess-doc-alist'." |
| 531 (let ((name (symbol-name symbol)) | |
| 532 (names custom-guess-name-alist) | |
| 533 current found) | |
| 534 (while names | |
| 535 (setq current (car names) | |
| 536 names (cdr names)) | |
| 537 (when (string-match (nth 0 current) name) | |
| 538 (setq found (nth 1 current) | |
| 539 names nil))) | |
| 540 (unless found | |
| 541 (let ((doc (documentation-property symbol 'variable-documentation)) | |
| 542 (docs custom-guess-doc-alist)) | |
| 25685 | 543 (when doc |
| 17415 | 544 (while docs |
| 545 (setq current (car docs) | |
| 546 docs (cdr docs)) | |
| 547 (when (string-match (nth 0 current) doc) | |
| 548 (setq found (nth 1 current) | |
| 549 docs nil)))))) | |
| 550 found)) | |
| 551 | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
552 ;;; Sorting. |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
553 |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
554 (defcustom custom-browse-sort-alphabetically nil |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
555 "If non-nil, sort members of each customization group alphabetically." |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
556 :type 'boolean |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
557 :group 'custom-browse) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
558 |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
559 (defcustom custom-browse-order-groups nil |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
560 "If non-nil, order group members within each customization group. |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
561 If `first', order groups before non-groups. |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
562 If `last', order groups after non-groups." |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
563 :type '(choice (const first) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
564 (const last) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
565 (const :tag "none" nil)) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
566 :group 'custom-browse) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
567 |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
568 (defcustom custom-browse-only-groups nil |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
569 "If non-nil, show group members only within each customization group." |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
570 :type 'boolean |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
571 :group 'custom-browse) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
572 |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
573 (defcustom custom-buffer-sort-alphabetically nil |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
574 "If non-nil, sort members of each customization group alphabetically." |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
575 :type 'boolean |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
576 :group 'custom-buffer) |
|
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
577 |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
578 (defcustom custom-buffer-order-groups 'last |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
579 "If non-nil, order group members within each customization group. |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
580 If `first', order groups before non-groups. |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
581 If `last', order groups after non-groups." |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
582 :type '(choice (const first) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
583 (const last) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
584 (const :tag "none" nil)) |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
585 :group 'custom-buffer) |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
586 |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
587 (defcustom custom-menu-sort-alphabetically nil |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
588 "If non-nil, sort members of each customization group alphabetically." |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
589 :type 'boolean |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
590 :group 'custom-menu) |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
591 |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
592 (defcustom custom-menu-order-groups 'first |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
593 "If non-nil, order group members within each customization group. |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
594 If `first', order groups before non-groups. |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
595 If `last', order groups after non-groups." |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
596 :type '(choice (const first) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
597 (const last) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
598 (const :tag "none" nil)) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
599 :group 'custom-menu) |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
600 |
|
22332
7ad747c6c5a9
(customize-group, customize-group-other-window)
Karl Heuer <kwzh@gnu.org>
parents:
22068
diff
changeset
|
601 ;;;###autoload (add-hook 'same-window-regexps "\\`\\*Customiz.*\\*\\'") |
|
7ad747c6c5a9
(customize-group, customize-group-other-window)
Karl Heuer <kwzh@gnu.org>
parents:
22068
diff
changeset
|
602 |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
603 (defun custom-sort-items (items sort-alphabetically order-groups) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
604 "Return a sorted copy of ITEMS. |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
605 ITEMS should be a `custom-group' property. |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
606 If SORT-ALPHABETICALLY non-nil, sort alphabetically. |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
607 If ORDER-GROUPS is `first' order groups before non-groups, if `last' order |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
608 groups after non-groups, if nil do not order groups at all." |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
609 (sort (copy-sequence items) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
610 (lambda (a b) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
611 (let ((typea (nth 1 a)) (typeb (nth 1 b)) |
|
28568
cfff869d8a3d
(custom-sort-items): Avoid symbol-name with new
Dave Love <fx@gnu.org>
parents:
28310
diff
changeset
|
612 (namea (nth 0 a)) (nameb (nth 0 b))) |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
613 (cond ((not order-groups) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
614 ;; Since we don't care about A and B order, maybe sort. |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
615 (when sort-alphabetically |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
616 (string-lessp namea nameb))) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
617 ((eq typea 'custom-group) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
618 ;; If B is also a group, maybe sort. Otherwise, order A and B. |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
619 (if (eq typeb 'custom-group) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
620 (when sort-alphabetically |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
621 (string-lessp namea nameb)) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
622 (eq order-groups 'first))) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
623 ((eq typeb 'custom-group) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
624 ;; Since A cannot be a group, order A and B. |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
625 (eq order-groups 'last)) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
626 (sort-alphabetically |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
627 ;; Since A and B cannot be groups, sort. |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
628 (string-lessp namea nameb))))))) |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
629 |
| 17415 | 630 ;;; Custom Mode Commands. |
| 17334 | 631 |
| 632 (defvar custom-options nil | |
| 633 "Customization widgets in the current buffer.") | |
| 634 | |
|
18435
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
635 (defun Custom-set () |
| 17334 | 636 "Set changes in all modified options." |
| 637 (interactive) | |
| 638 (let ((children custom-options)) | |
|
28700
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
639 (mapc (lambda (child) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
640 (when (eq (widget-get child :custom-state) 'modified) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
641 (widget-apply child :custom-set))) |
| 17334 | 642 children))) |
| 643 | |
|
18435
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
644 (defun Custom-save () |
| 17334 | 645 "Set all modified group members and save them." |
| 646 (interactive) | |
| 647 (let ((children custom-options)) | |
|
28700
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
648 (mapc (lambda (child) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
649 (when (memq (widget-get child :custom-state) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
650 '(modified set changed rogue)) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
651 (widget-apply child :custom-save))) |
| 17334 | 652 children)) |
| 653 (custom-save-all)) | |
| 654 | |
| 25685 | 655 (defvar custom-reset-menu |
|
18435
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
656 '(("Current" . Custom-reset-current) |
|
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
657 ("Saved" . Custom-reset-saved) |
|
26625
faf989c7a28e
(Custom-reset-standard): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
26451
diff
changeset
|
658 ("Erase Customization (use standard settings)" . Custom-reset-standard)) |
| 17334 | 659 "Alist of actions for the `Reset' button. |
| 660 The key is a string containing the name of the action, the value is a | |
| 28130 | 661 Lisp function taking the widget as an element which will be called |
| 17334 | 662 when the action is chosen.") |
| 663 | |
| 664 (defun custom-reset (event) | |
| 665 "Select item from reset menu." | |
| 666 (let* ((completion-ignore-case t) | |
| 667 (answer (widget-choose "Reset to" | |
| 668 custom-reset-menu | |
| 669 event))) | |
| 670 (if answer | |
| 671 (funcall answer)))) | |
| 672 | |
|
18435
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
673 (defun Custom-reset-current (&rest ignore) |
| 17334 | 674 "Reset all modified group members to their current value." |
| 675 (interactive) | |
| 676 (let ((children custom-options)) | |
|
28700
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
677 (mapc (lambda (widget) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
678 (and (default-boundp (widget-value widget)) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
679 (if (memq (widget-get widget :custom-state) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
680 '(modified changed)) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
681 (widget-apply widget :custom-reset-current)))) |
| 17334 | 682 children))) |
| 683 | |
|
18435
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
684 (defun Custom-reset-saved (&rest ignore) |
| 17334 | 685 "Reset all modified or set group members to their saved value." |
| 686 (interactive) | |
| 687 (let ((children custom-options)) | |
|
28700
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
688 (mapc (lambda (widget) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
689 (and (get (widget-value widget) 'saved-value) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
690 (if (memq (widget-get widget :custom-state) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
691 '(modified set changed rogue)) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
692 (widget-apply widget :custom-reset-saved)))) |
| 17334 | 693 children))) |
| 694 | |
|
18435
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
695 (defun Custom-reset-standard (&rest ignore) |
|
26625
faf989c7a28e
(Custom-reset-standard): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
26451
diff
changeset
|
696 "Erase all customization (either current or saved) for the group members. |
|
faf989c7a28e
(Custom-reset-standard): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
26451
diff
changeset
|
697 The immediate result is to restore them to their standard settings. |
|
faf989c7a28e
(Custom-reset-standard): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
26451
diff
changeset
|
698 This operation eliminates any saved settings for the group members, |
|
faf989c7a28e
(Custom-reset-standard): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
26451
diff
changeset
|
699 making them as if they had never been customized at all." |
| 17334 | 700 (interactive) |
| 701 (let ((children custom-options)) | |
|
28700
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
702 (mapc (lambda (widget) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
703 (and (get (widget-value widget) 'standard-value) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
704 (if (memq (widget-get widget :custom-state) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
705 '(modified set changed saved rogue)) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
706 (widget-apply widget :custom-reset-standard)))) |
| 17334 | 707 children))) |
| 708 | |
| 709 ;;; The Customize Commands | |
| 710 | |
| 25685 | 711 (defun custom-prompt-variable (prompt-var prompt-val &optional comment) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
712 "Prompt for a variable and a value and return them as a list. |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
713 PROMPT-VAR is the prompt for the variable, and PROMPT-VAL is the |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
714 prompt for the value. The %s escape in PROMPT-VAL is replaced with |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
715 the name of the variable. |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
716 |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
717 If the variable has a `variable-interactive' property, that is used as if |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
718 it were the arg to `interactive' (which see) to interactively read the value. |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
719 |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
720 If the variable has a `custom-type' property, it must be a widget and the |
| 25685 | 721 `:prompt-value' property of that widget will be used for reading the value. |
| 722 | |
| 723 If optional COMMENT argument is non nil, also prompt for a comment and return | |
| 724 it as the third element in the list." | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
725 (let* ((var (read-variable prompt-var)) |
| 25685 | 726 (minibuffer-help-form '(describe-variable var)) |
| 727 (val | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
728 (let ((prop (get var 'variable-interactive)) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
729 (type (get var 'custom-type)) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
730 (prompt (format prompt-val var))) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
731 (unless (listp type) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
732 (setq type (list type))) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
733 (cond (prop |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
734 ;; Use VAR's `variable-interactive' property |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
735 ;; as an interactive spec for prompting. |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
736 (call-interactively (list 'lambda '(arg) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
737 (list 'interactive prop) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
738 'arg))) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
739 (type |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
740 (widget-prompt-value type |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
741 prompt |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
742 (if (boundp var) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
743 (symbol-value var)) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
744 (not (boundp var)))) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
745 (t |
| 25685 | 746 (eval-minibuffer prompt)))))) |
| 747 (if comment | |
| 748 (list var val | |
| 749 (read-string "Comment: " (get var 'variable-comment))) | |
| 750 (list var val)))) | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
751 |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
752 ;;;###autoload |
| 25685 | 753 (defun customize-set-value (var val &optional comment) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
754 "Set VARIABLE to VALUE. VALUE is a Lisp object. |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
755 |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
756 If VARIABLE has a `variable-interactive' property, that is used as if |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
757 it were the arg to `interactive' (which see) to interactively read the value. |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
758 |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
759 If VARIABLE has a `custom-type' property, it must be a widget and the |
| 25685 | 760 `:prompt-value' property of that widget will be used for reading the value. |
| 761 | |
| 762 If given a prefix (or a COMMENT argument), also prompt for a comment." | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
763 (interactive (custom-prompt-variable "Set variable: " |
| 25685 | 764 "Set %s to value: " |
| 765 current-prefix-arg)) | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
766 |
| 25685 | 767 (set var val) |
| 768 (cond ((string= comment "") | |
| 769 (put var 'variable-comment nil)) | |
| 770 (comment | |
| 771 (put var 'variable-comment comment)))) | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
772 |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
773 ;;;###autoload |
| 28130 | 774 (defun customize-set-variable (variable value &optional comment) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
775 "Set the default for VARIABLE to VALUE. VALUE is a Lisp object. |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
776 |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
777 If VARIABLE has a `custom-set' property, that is used for setting |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
778 VARIABLE, otherwise `set-default' is used. |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
779 |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
780 The `customized-value' property of the VARIABLE will be set to a list |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
781 with a quoted VALUE as its sole list member. |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
782 |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
783 If VARIABLE has a `variable-interactive' property, that is used as if |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
784 it were the arg to `interactive' (which see) to interactively read the value. |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
785 |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
786 If VARIABLE has a `custom-type' property, it must be a widget and the |
| 25685 | 787 `:prompt-value' property of that widget will be used for reading the value. |
| 788 | |
| 789 If given a prefix (or a COMMENT argument), also prompt for a comment." | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
790 (interactive (custom-prompt-variable "Set variable: " |
| 25685 | 791 "Set customized value for %s to: " |
| 792 current-prefix-arg)) | |
| 28130 | 793 (funcall (or (get variable 'custom-set) 'set-default) variable value) |
| 794 (put variable 'customized-value (list (custom-quote value))) | |
| 25685 | 795 (cond ((string= comment "") |
| 28130 | 796 (put variable 'variable-comment nil) |
| 797 (put variable 'customized-variable-comment nil)) | |
| 25685 | 798 (comment |
| 28130 | 799 (put variable 'variable-comment comment) |
| 800 (put variable 'customized-variable-comment comment)))) | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
801 |
| 17334 | 802 ;;;###autoload |
| 28130 | 803 (defun customize-save-variable (var value &optional comment) |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
804 "Set the default for VARIABLE to VALUE, and save it for future sessions. |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
805 If VARIABLE has a `custom-set' property, that is used for setting |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
806 VARIABLE, otherwise `set-default' is used. |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
807 |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
808 The `customized-value' property of the VARIABLE will be set to a list |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
809 with a quoted VALUE as its sole list member. |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
810 |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
811 If VARIABLE has a `variable-interactive' property, that is used as if |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
812 it were the arg to `interactive' (which see) to interactively read the value. |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
813 |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
814 If VARIABLE has a `custom-type' property, it must be a widget and the |
| 25685 | 815 `:prompt-value' property of that widget will be used for reading the value. |
| 816 | |
| 817 If given a prefix (or a COMMENT argument), also prompt for a comment." | |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
818 (interactive (custom-prompt-variable "Set and ave variable: " |
| 25685 | 819 "Set and save value for %s as: " |
| 820 current-prefix-arg)) | |
| 28130 | 821 (funcall (or (get var 'custom-set) 'set-default) var value) |
| 822 (put var 'saved-value (list (custom-quote value))) | |
| 25685 | 823 (cond ((string= comment "") |
| 824 (put var 'variable-comment nil) | |
| 825 (put var 'saved-variable-comment nil)) | |
| 826 (comment | |
| 827 (put var 'variable-comment comment) | |
| 828 (put var 'saved-variable-comment comment))) | |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
829 (custom-save-all)) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
830 |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
831 ;;;###autoload |
|
17641
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
832 (defun customize () |
|
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
833 "Select a customization buffer which you can use to set user options. |
|
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
834 User options are structured into \"groups\". |
|
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
835 Initially the top-level group `Emacs' and its immediate subgroups |
|
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
836 are shown; the contents of those subgroups are initially hidden." |
|
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
837 (interactive) |
| 17703 | 838 (customize-group 'emacs)) |
|
17641
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
839 |
|
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
840 ;;;###autoload |
|
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
841 (defun customize-group (group) |
|
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
842 "Customize GROUP, which must be a customization group." |
|
18352
4951826c2ed2
(customize-group): Ignore case in completion.
Richard M. Stallman <rms@gnu.org>
parents:
18336
diff
changeset
|
843 (interactive (list (let ((completion-ignore-case t)) |
|
4951826c2ed2
(customize-group): Ignore case in completion.
Richard M. Stallman <rms@gnu.org>
parents:
18336
diff
changeset
|
844 (completing-read "Customize group: (default emacs) " |
| 25685 | 845 obarray |
|
18352
4951826c2ed2
(customize-group): Ignore case in completion.
Richard M. Stallman <rms@gnu.org>
parents:
18336
diff
changeset
|
846 (lambda (symbol) |
|
19886
539d06d1f0da
(customize-group): Handle groups not yet loaded.
Richard M. Stallman <rms@gnu.org>
parents:
19883
diff
changeset
|
847 (or (get symbol 'custom-loads) |
|
539d06d1f0da
(customize-group): Handle groups not yet loaded.
Richard M. Stallman <rms@gnu.org>
parents:
19883
diff
changeset
|
848 (get symbol 'custom-group))) |
|
18352
4951826c2ed2
(customize-group): Ignore case in completion.
Richard M. Stallman <rms@gnu.org>
parents:
18336
diff
changeset
|
849 t)))) |
|
17641
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
850 (when (stringp group) |
|
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
851 (if (string-equal "" group) |
|
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
852 (setq group 'emacs) |
|
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
853 (setq group (intern group)))) |
|
19886
539d06d1f0da
(customize-group): Handle groups not yet loaded.
Richard M. Stallman <rms@gnu.org>
parents:
19883
diff
changeset
|
854 (or (get group 'custom-group) |
|
539d06d1f0da
(customize-group): Handle groups not yet loaded.
Richard M. Stallman <rms@gnu.org>
parents:
19883
diff
changeset
|
855 (custom-load-symbol group)) |
|
18359
057bb638549c
(custom-nest-groups): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18352
diff
changeset
|
856 (let ((name (format "*Customize Group: %s*" |
|
057bb638549c
(custom-nest-groups): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18352
diff
changeset
|
857 (custom-unlispify-tag-name group)))) |
|
057bb638549c
(custom-nest-groups): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18352
diff
changeset
|
858 (if (get-buffer name) |
|
22332
7ad747c6c5a9
(customize-group, customize-group-other-window)
Karl Heuer <kwzh@gnu.org>
parents:
22068
diff
changeset
|
859 (pop-to-buffer name) |
|
18359
057bb638549c
(custom-nest-groups): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18352
diff
changeset
|
860 (custom-buffer-create (list (list group 'custom-group)) |
|
18571
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
861 name |
|
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
862 (concat " for group " |
|
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
863 (custom-unlispify-tag-name group)))))) |
| 17334 | 864 |
| 865 ;;;###autoload | |
|
22001
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
866 (defun customize-group-other-window (group) |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
867 "Customize GROUP, which must be a customization group." |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
868 (interactive (list (let ((completion-ignore-case t)) |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
869 (completing-read "Customize group: (default emacs) " |
| 25685 | 870 obarray |
|
22001
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
871 (lambda (symbol) |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
872 (or (get symbol 'custom-loads) |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
873 (get symbol 'custom-group))) |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
874 t)))) |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
875 (when (stringp group) |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
876 (if (string-equal "" group) |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
877 (setq group 'emacs) |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
878 (setq group (intern group)))) |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
879 (or (get group 'custom-group) |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
880 (custom-load-symbol group)) |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
881 (let ((name (format "*Customize Group: %s*" |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
882 (custom-unlispify-tag-name group)))) |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
883 (if (get-buffer name) |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
884 (let ((window (selected-window))) |
|
22348
86cb09249796
(customize-group-other-window): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents:
22332
diff
changeset
|
885 (pop-to-buffer name) |
|
22001
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
886 (select-window window)) |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
887 (custom-buffer-create-other-window |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
888 (list (list group 'custom-group)) |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
889 name |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
890 (concat " for group " |
|
e35aafba190f
(customize-group-other-window): Handle groups not
Richard M. Stallman <rms@gnu.org>
parents:
21669
diff
changeset
|
891 (custom-unlispify-tag-name group)))))) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
892 |
| 18089 | 893 ;;;###autoload |
| 894 (defalias 'customize-variable 'customize-option) | |
|
18086
dbae3eb8b351
(customize-option): Renamed from custom-variable.
Richard M. Stallman <rms@gnu.org>
parents:
18085
diff
changeset
|
895 |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
896 ;;;###autoload |
|
18086
dbae3eb8b351
(customize-option): Renamed from custom-variable.
Richard M. Stallman <rms@gnu.org>
parents:
18085
diff
changeset
|
897 (defun customize-option (symbol) |
|
dbae3eb8b351
(customize-option): Renamed from custom-variable.
Richard M. Stallman <rms@gnu.org>
parents:
18085
diff
changeset
|
898 "Customize SYMBOL, which must be a user option variable." |
| 17415 | 899 (interactive (custom-variable-prompt)) |
|
23190
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
900 ;; If we don't have SYMBOL's real definition loaded, |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
901 ;; try to load it. |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
902 (unless (get symbol 'custom-type) |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
903 (let ((loaddefs-file (locate-library "loaddefs.el" t)) |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
904 file) |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
905 ;; See if it is autoloaded from some library. |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
906 (when loaddefs-file |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
907 (with-temp-buffer |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
908 (insert-file-contents loaddefs-file) |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
909 (when (re-search-forward (concat "^(defvar " (symbol-name symbol)) |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
910 nil t) |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
911 (search-backward "\n;;; Generated autoloads from ") |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
912 (goto-char (match-end 0)) |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
913 (setq file (buffer-substring (point) |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
914 (progn (end-of-line) (point))))))) |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
915 ;; If it is, load that library. |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
916 (when file |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
917 (when (string-match "\\.el\\'" file) |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
918 (setq file (substring file 0 (match-beginning 0)))) |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
919 (load file)))) |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
920 (unless (get symbol 'custom-type) |
|
0fe0fe296153
(customize-option): Refuse to customize
Karl Heuer <kwzh@gnu.org>
parents:
23105
diff
changeset
|
921 (error "Variable %s cannot be customized" symbol)) |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
922 (custom-buffer-create (list (list symbol 'custom-variable)) |
|
18086
dbae3eb8b351
(customize-option): Renamed from custom-variable.
Richard M. Stallman <rms@gnu.org>
parents:
18085
diff
changeset
|
923 (format "*Customize Option: %s*" |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
924 (custom-unlispify-tag-name symbol)))) |
| 17334 | 925 |
|
23105
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
926 (defvar customize-changed-options-previous-release "20.2" |
|
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
927 "Version for `customize-changed-options' to refer back to by default.") |
|
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
928 |
| 17334 | 929 ;;;###autoload |
|
20444
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
930 (defun customize-changed-options (since-version) |
|
23105
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
931 "Customize all user option variables changed in Emacs itself. |
|
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
932 This includes new user option variables and faces, and new |
|
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
933 customization groups, as well as older options and faces whose default |
|
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
934 values have changed since the previous major Emacs release. |
|
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
935 |
|
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
936 With argument SINCE-VERSION (a string), customize all user option |
|
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
937 variables that were added (or their meanings were changed) since that |
|
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
938 version." |
|
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
939 |
|
20444
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
940 (interactive "sCustomize options changed, since version (default all versions): ") |
|
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
941 (if (equal since-version "") |
|
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
942 (setq since-version nil)) |
|
23105
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
943 (unless since-version |
|
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
944 (setq since-version customize-changed-options-previous-release)) |
|
22538
2649d061d370
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
22348
diff
changeset
|
945 (let ((found nil) |
|
2649d061d370
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
22348
diff
changeset
|
946 (versions nil)) |
|
20444
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
947 (mapatoms (lambda (symbol) |
|
21649
840699d18eab
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
20974
diff
changeset
|
948 (and (or (boundp symbol) |
|
22538
2649d061d370
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
22348
diff
changeset
|
949 ;; For variables not yet loaded. |
|
2649d061d370
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
22348
diff
changeset
|
950 (get symbol 'standard-value) |
|
21649
840699d18eab
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
20974
diff
changeset
|
951 ;; For groups the previous test fails, this one |
|
840699d18eab
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
20974
diff
changeset
|
952 ;; could be used to determine if symbol is a |
|
840699d18eab
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
20974
diff
changeset
|
953 ;; group. Is there a better way for this? |
|
840699d18eab
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
20974
diff
changeset
|
954 (get symbol 'group-documentation)) |
|
20444
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
955 (let ((version (get symbol 'custom-version))) |
|
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
956 (and version |
|
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
957 (or (null since-version) |
|
22538
2649d061d370
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
22348
diff
changeset
|
958 (customize-version-lessp since-version version)) |
| 25685 | 959 (if (member version versions) |
|
22538
2649d061d370
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
22348
diff
changeset
|
960 t |
|
2649d061d370
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
22348
diff
changeset
|
961 ;;; Collect all versions that we use. |
|
2649d061d370
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
22348
diff
changeset
|
962 (push version versions)))) |
|
20444
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
963 (setq found |
|
21649
840699d18eab
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
20974
diff
changeset
|
964 ;; We have to set the right thing here, |
|
840699d18eab
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
20974
diff
changeset
|
965 ;; depending if we have a group or a |
| 25685 | 966 ;; variable. |
|
21649
840699d18eab
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
20974
diff
changeset
|
967 (if (get symbol 'group-documentation) |
|
840699d18eab
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
20974
diff
changeset
|
968 (cons (list symbol 'custom-group) found) |
|
840699d18eab
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
20974
diff
changeset
|
969 (cons (list symbol 'custom-variable) found)))))) |
|
20444
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
970 (if (not found) |
|
23105
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
971 (error "No user option defaults have been changed since Emacs %s" |
|
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
972 since-version) |
|
22667
8e8001567771
(customize-changed-options): Clean up previous change.
Richard M. Stallman <rms@gnu.org>
parents:
22600
diff
changeset
|
973 (let ((flist nil)) |
|
8e8001567771
(customize-changed-options): Clean up previous change.
Richard M. Stallman <rms@gnu.org>
parents:
22600
diff
changeset
|
974 (while versions |
| 25685 | 975 (push (copy-sequence |
|
22667
8e8001567771
(customize-changed-options): Clean up previous change.
Richard M. Stallman <rms@gnu.org>
parents:
22600
diff
changeset
|
976 (cdr (assoc (car versions) custom-versions-load-alist))) |
|
8e8001567771
(customize-changed-options): Clean up previous change.
Richard M. Stallman <rms@gnu.org>
parents:
22600
diff
changeset
|
977 flist) |
|
8e8001567771
(customize-changed-options): Clean up previous change.
Richard M. Stallman <rms@gnu.org>
parents:
22600
diff
changeset
|
978 (setq versions (cdr versions))) |
| 25685 | 979 (put 'custom-versions-load-alist 'custom-loads |
|
22667
8e8001567771
(customize-changed-options): Clean up previous change.
Richard M. Stallman <rms@gnu.org>
parents:
22600
diff
changeset
|
980 ;; Get all the files that correspond to element from the |
|
8e8001567771
(customize-changed-options): Clean up previous change.
Richard M. Stallman <rms@gnu.org>
parents:
22600
diff
changeset
|
981 ;; VERSIONS list. This could use some simplification. |
|
22538
2649d061d370
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
22348
diff
changeset
|
982 (apply 'nconc flist))) |
|
2649d061d370
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
22348
diff
changeset
|
983 ;; Because we set all the files needed to be loaded as a |
|
2649d061d370
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
22348
diff
changeset
|
984 ;; `custom-loads' property to `custom-versions-load-alist' this |
|
2649d061d370
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
22348
diff
changeset
|
985 ;; call will actually load them. |
|
2649d061d370
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
22348
diff
changeset
|
986 (custom-load-symbol 'custom-versions-load-alist) |
|
2649d061d370
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
22348
diff
changeset
|
987 ;; Clean up |
|
2649d061d370
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
22348
diff
changeset
|
988 (put 'custom-versions-load-alist 'custom-loads nil) |
|
2649d061d370
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
22348
diff
changeset
|
989 (custom-buffer-create (custom-sort-items found t 'first) |
|
20444
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
990 "*Customize Changed Options*")))) |
|
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
991 |
|
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
992 (defun customize-version-lessp (version1 version2) |
|
23105
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
993 ;; In case someone made a mistake and left out the quotes |
|
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
994 ;; in the :version value. |
|
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
995 (if (numberp version2) |
|
a47a69af14c8
(customize-version-lessp): Handle a number as VERSION2.
Karl Heuer <kwzh@gnu.org>
parents:
22667
diff
changeset
|
996 (setq version2 (prin1-to-string version2))) |
|
20444
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
997 (let (major1 major2 minor1 minor2) |
|
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
998 (string-match "\\([0-9]+\\)[.]\\([0-9]+\\)" version1) |
|
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
999 (setq major1 (read (match-string 1 version1))) |
|
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
1000 (setq minor1 (read (match-string 2 version1))) |
|
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
1001 (string-match "\\([0-9]+\\)[.]\\([0-9]+\\)" version2) |
|
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
1002 (setq major2 (read (match-string 1 version2))) |
|
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
1003 (setq minor2 (read (match-string 2 version2))) |
|
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
1004 (or (< major1 major2) |
|
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
1005 (and (= major1 major2) |
|
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
1006 (< minor1 minor2))))) |
|
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
1007 |
|
a9fbb6791eb7
(customize-changed-options): New function.
Karl Heuer <kwzh@gnu.org>
parents:
20411
diff
changeset
|
1008 ;;;###autoload |
|
18139
ee3c0d09dcd3
Synched with 1.9908.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18131
diff
changeset
|
1009 (defalias 'customize-variable-other-window 'customize-option-other-window) |
|
ee3c0d09dcd3
Synched with 1.9908.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18131
diff
changeset
|
1010 |
|
ee3c0d09dcd3
Synched with 1.9908.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18131
diff
changeset
|
1011 ;;;###autoload |
|
18086
dbae3eb8b351
(customize-option): Renamed from custom-variable.
Richard M. Stallman <rms@gnu.org>
parents:
18085
diff
changeset
|
1012 (defun customize-option-other-window (symbol) |
|
dbae3eb8b351
(customize-option): Renamed from custom-variable.
Richard M. Stallman <rms@gnu.org>
parents:
18085
diff
changeset
|
1013 "Customize SYMBOL, which must be a user option variable. |
| 17415 | 1014 Show the buffer in another window, but don't select it." |
| 1015 (interactive (custom-variable-prompt)) | |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1016 (custom-buffer-create-other-window |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1017 (list (list symbol 'custom-variable)) |
|
18086
dbae3eb8b351
(customize-option): Renamed from custom-variable.
Richard M. Stallman <rms@gnu.org>
parents:
18085
diff
changeset
|
1018 (format "*Customize Option: %s*" (custom-unlispify-tag-name symbol)))) |
| 17415 | 1019 |
| 1020 ;;;###autoload | |
| 17334 | 1021 (defun customize-face (&optional symbol) |
| 1022 "Customize SYMBOL, which should be a face name or nil. | |
| 1023 If SYMBOL is nil, customize all faces." | |
| 25685 | 1024 (interactive (list (completing-read "Customize face: (default all) " |
|
26451
91e697e38599
(customize-face, customize-face-other-window): Require match from
Dave Love <fx@gnu.org>
parents:
25847
diff
changeset
|
1025 obarray 'custom-facep t))) |
| 17334 | 1026 (if (or (null symbol) (and (stringp symbol) (zerop (length symbol)))) |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1027 (custom-buffer-create (custom-sort-items |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1028 (mapcar (lambda (symbol) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1029 (list symbol 'custom-face)) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1030 (face-list)) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1031 t nil) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1032 "*Customize Faces*") |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1033 (when (stringp symbol) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1034 (setq symbol (intern symbol))) |
| 17334 | 1035 (unless (symbolp symbol) |
| 1036 (error "Should be a symbol %S" symbol)) | |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1037 (custom-buffer-create (list (list symbol 'custom-face)) |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1038 (format "*Customize Face: %s*" |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1039 (custom-unlispify-tag-name symbol))))) |
| 17334 | 1040 |
| 1041 ;;;###autoload | |
| 17415 | 1042 (defun customize-face-other-window (&optional symbol) |
| 28130 | 1043 "Show customization buffer for face SYMBOL in other window." |
| 25685 | 1044 (interactive (list (completing-read "Customize face: " |
|
26451
91e697e38599
(customize-face, customize-face-other-window): Require match from
Dave Love <fx@gnu.org>
parents:
25847
diff
changeset
|
1045 obarray 'custom-facep t))) |
| 17415 | 1046 (if (or (null symbol) (and (stringp symbol) (zerop (length symbol)))) |
| 1047 () | |
| 1048 (if (stringp symbol) | |
| 1049 (setq symbol (intern symbol))) | |
| 1050 (unless (symbolp symbol) | |
| 1051 (error "Should be a symbol %S" symbol)) | |
| 25685 | 1052 (custom-buffer-create-other-window |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1053 (list (list symbol 'custom-face)) |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1054 (format "*Customize Face: %s*" (custom-unlispify-tag-name symbol))))) |
| 17415 | 1055 |
| 1056 ;;;###autoload | |
| 17334 | 1057 (defun customize-customized () |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1058 "Customize all user options set since the last save in this session." |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1059 (interactive) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1060 (let ((found nil)) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1061 (mapatoms (lambda (symbol) |
| 25685 | 1062 (and (or (get symbol 'customized-face) |
| 1063 (get symbol 'customized-face-comment)) | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1064 (custom-facep symbol) |
|
18336
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1065 (push (list symbol 'custom-face) found)) |
| 25685 | 1066 (and (or (get symbol 'customized-value) |
| 1067 (get symbol 'customized-variable-comment)) | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1068 (boundp symbol) |
|
18336
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1069 (push (list symbol 'custom-variable) found)))) |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1070 (if (not found) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1071 (error "No customized user options") |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1072 (custom-buffer-create (custom-sort-items found t nil) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1073 "*Customize Customized*")))) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1074 |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1075 ;;;###autoload |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1076 (defun customize-saved () |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1077 "Customize all already saved user options." |
| 17334 | 1078 (interactive) |
| 1079 (let ((found nil)) | |
| 1080 (mapatoms (lambda (symbol) | |
| 25685 | 1081 (and (or (get symbol 'saved-face) |
| 1082 (get symbol 'saved-face-comment)) | |
| 17334 | 1083 (custom-facep symbol) |
|
18336
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1084 (push (list symbol 'custom-face) found)) |
| 25685 | 1085 (and (or (get symbol 'saved-value) |
| 1086 (get symbol 'saved-variable-comment)) | |
| 17334 | 1087 (boundp symbol) |
|
18336
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1088 (push (list symbol 'custom-variable) found)))) |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1089 (if (not found ) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1090 (error "No saved user options") |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1091 (custom-buffer-create (custom-sort-items found t nil) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1092 "*Customize Saved*")))) |
| 17334 | 1093 |
| 1094 ;;;###autoload | |
| 1095 (defun customize-apropos (regexp &optional all) | |
| 1096 "Customize all user options matching REGEXP. | |
|
18336
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1097 If ALL is `options', include only options. |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1098 If ALL is `faces', include only faces. |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1099 If ALL is `groups', include only groups. |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1100 If ALL is t (interactively, with prefix arg), include options which are not |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1101 user-settable, as well as faces and groups." |
| 17334 | 1102 (interactive "sCustomize regexp: \nP") |
| 1103 (let ((found nil)) | |
| 1104 (mapatoms (lambda (symbol) | |
| 1105 (when (string-match regexp (symbol-name symbol)) | |
|
18336
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1106 (when (and (not (memq all '(faces options))) |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1107 (get symbol 'custom-group)) |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1108 (push (list symbol 'custom-group) found)) |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1109 (when (and (not (memq all '(options groups))) |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1110 (custom-facep symbol)) |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1111 (push (list symbol 'custom-face) found)) |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1112 (when (and (not (memq all '(groups faces))) |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1113 (boundp symbol) |
| 17334 | 1114 (or (get symbol 'saved-value) |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1115 (get symbol 'standard-value) |
|
18336
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1116 (if (memq all '(nil options)) |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1117 (user-variable-p symbol) |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1118 (get symbol 'variable-documentation)))) |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1119 (push (list symbol 'custom-variable) found))))) |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1120 (if (not found) |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1121 (error "No matches") |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1122 (custom-buffer-create (custom-sort-items found t |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1123 custom-buffer-order-groups) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1124 "*Customize Apropos*")))) |
|
18336
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1125 |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1126 ;;;###autoload |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1127 (defun customize-apropos-options (regexp &optional arg) |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1128 "Customize all user options matching REGEXP. |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1129 With prefix arg, include options which are not user-settable." |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1130 (interactive "sCustomize regexp: \nP") |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1131 (customize-apropos regexp (or arg 'options))) |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1132 |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1133 ;;;###autoload |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1134 (defun customize-apropos-faces (regexp) |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1135 "Customize all user faces matching REGEXP." |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1136 (interactive "sCustomize regexp: \n") |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1137 (customize-apropos regexp 'faces)) |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1138 |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1139 ;;;###autoload |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1140 (defun customize-apropos-groups (regexp) |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1141 "Customize all user groups matching REGEXP." |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1142 (interactive "sCustomize regexp: \n") |
|
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
1143 (customize-apropos regexp 'groups)) |
| 17334 | 1144 |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1145 ;;; Buffer. |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1146 |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1147 (defcustom custom-buffer-style 'links |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1148 "Control the presentation style for customization buffers. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1149 The value should be a symbol, one of: |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1150 |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1151 brackets: groups nest within each other with big horizontal brackets. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1152 links: groups have links to subgroups." |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1153 :type '(radio (const brackets) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1154 (const links)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1155 :group 'custom-buffer) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1156 |
|
26451
91e697e38599
(customize-face, customize-face-other-window): Require match from
Dave Love <fx@gnu.org>
parents:
25847
diff
changeset
|
1157 ;; If we pass BUFFER to `bury-buffer', the buffer isn't removed from |
|
91e697e38599
(customize-face, customize-face-other-window): Require match from
Dave Love <fx@gnu.org>
parents:
25847
diff
changeset
|
1158 ;; the window. |
|
25840
6beb132dd31c
(custom-bury-buffer): New function.
Dave Love <fx@gnu.org>
parents:
25824
diff
changeset
|
1159 (defun custom-bury-buffer (buffer) |
|
6beb132dd31c
(custom-bury-buffer): New function.
Dave Love <fx@gnu.org>
parents:
25824
diff
changeset
|
1160 (bury-buffer)) |
|
6beb132dd31c
(custom-bury-buffer): New function.
Dave Love <fx@gnu.org>
parents:
25824
diff
changeset
|
1161 |
|
26451
91e697e38599
(customize-face, customize-face-other-window): Require match from
Dave Love <fx@gnu.org>
parents:
25847
diff
changeset
|
1162 (defcustom custom-buffer-done-function 'custom-bury-buffer |
| 25685 | 1163 "*Function called to remove a Custom buffer when the user is done with it. |
| 1164 Called with one argument, the buffer to remove." | |
|
26451
91e697e38599
(customize-face, customize-face-other-window): Require match from
Dave Love <fx@gnu.org>
parents:
25847
diff
changeset
|
1165 :type '(choice (function-item :tag "Bury buffer" custom-bury-buffer) |
|
91e697e38599
(customize-face, customize-face-other-window): Require match from
Dave Love <fx@gnu.org>
parents:
25847
diff
changeset
|
1166 (function-item :tag "Kill buffer" kill-buffer) |
| 25685 | 1167 (function :tag "Other")) |
| 1168 :version "21.1" | |
| 1169 :group 'custom-buffer) | |
| 1170 | |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1171 (defcustom custom-buffer-indent 3 |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1172 "Number of spaces to indent nested groups." |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1173 :type 'integer |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1174 :group 'custom-buffer) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1175 |
| 17334 | 1176 ;;;###autoload |
|
18571
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
1177 (defun custom-buffer-create (options &optional name description) |
| 17334 | 1178 "Create a buffer containing OPTIONS. |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1179 Optional NAME is the name of the buffer. |
| 17334 | 1180 OPTIONS should be an alist of the form ((SYMBOL WIDGET)...), where |
| 1181 SYMBOL is a customization option, and WIDGET is a widget for editing | |
| 1182 that option." | |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1183 (unless name (setq name "*Customization*")) |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1184 (kill-buffer (get-buffer-create name)) |
|
22332
7ad747c6c5a9
(customize-group, customize-group-other-window)
Karl Heuer <kwzh@gnu.org>
parents:
22068
diff
changeset
|
1185 (pop-to-buffer (get-buffer-create name)) |
|
18571
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
1186 (custom-buffer-create-internal options description)) |
| 17415 | 1187 |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1188 ;;;###autoload |
|
18571
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
1189 (defun custom-buffer-create-other-window (options &optional name description) |
| 17415 | 1190 "Create a buffer containing OPTIONS. |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1191 Optional NAME is the name of the buffer. |
| 17415 | 1192 OPTIONS should be an alist of the form ((SYMBOL WIDGET)...), where |
| 1193 SYMBOL is a customization option, and WIDGET is a widget for editing | |
| 1194 that option." | |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1195 (unless name (setq name "*Customization*")) |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1196 (kill-buffer (get-buffer-create name)) |
|
22332
7ad747c6c5a9
(customize-group, customize-group-other-window)
Karl Heuer <kwzh@gnu.org>
parents:
22068
diff
changeset
|
1197 (let ((window (selected-window)) |
|
7ad747c6c5a9
(customize-group, customize-group-other-window)
Karl Heuer <kwzh@gnu.org>
parents:
22068
diff
changeset
|
1198 (pop-up-windows t) |
|
7ad747c6c5a9
(customize-group, customize-group-other-window)
Karl Heuer <kwzh@gnu.org>
parents:
22068
diff
changeset
|
1199 (special-display-buffer-names nil) |
|
7ad747c6c5a9
(customize-group, customize-group-other-window)
Karl Heuer <kwzh@gnu.org>
parents:
22068
diff
changeset
|
1200 (special-display-regexps nil) |
|
7ad747c6c5a9
(customize-group, customize-group-other-window)
Karl Heuer <kwzh@gnu.org>
parents:
22068
diff
changeset
|
1201 (same-window-buffer-names nil) |
|
7ad747c6c5a9
(customize-group, customize-group-other-window)
Karl Heuer <kwzh@gnu.org>
parents:
22068
diff
changeset
|
1202 (same-window-regexps nil)) |
|
7ad747c6c5a9
(customize-group, customize-group-other-window)
Karl Heuer <kwzh@gnu.org>
parents:
22068
diff
changeset
|
1203 (pop-to-buffer (get-buffer-create name)) |
|
18571
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
1204 (custom-buffer-create-internal options description) |
| 17415 | 1205 (select-window window))) |
| 18089 | 1206 |
| 1207 (defcustom custom-reset-button-menu nil | |
| 1208 "If non-nil, only show a single reset button in customize buffers. | |
| 1209 This button will have a menu with all three reset operations." | |
| 1210 :type 'boolean | |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1211 :group 'custom-buffer) |
| 17415 | 1212 |
| 25685 | 1213 (defun Custom-buffer-done (&rest ignore) |
| 1214 "Remove current buffer by calling `custom-buffer-done-function'." | |
| 1215 (interactive) | |
| 1216 (funcall custom-buffer-done-function (current-buffer))) | |
| 1217 | |
| 1218 (defcustom custom-raised-buttons (not (equal (face-valid-attribute-values :box) | |
| 1219 '(("unspecified" . unspecified)))) | |
| 1220 "If non-nil, indicate active buttons in a `raised-button' style. | |
| 1221 Otherwise use brackets." | |
| 1222 :type 'boolean | |
| 1223 :version "21.1" | |
| 1224 :group 'custom-buffer) | |
| 1225 | |
|
18571
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
1226 (defun custom-buffer-create-internal (options &optional description) |
| 17415 | 1227 (message "Creating customization buffer...") |
| 17334 | 1228 (custom-mode) |
|
18571
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
1229 (widget-insert "This is a customization buffer") |
|
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
1230 (if description |
|
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
1231 (widget-insert description)) |
| 25685 | 1232 (widget-insert (format ". |
| 1233 %s show active fields; type RET or click mouse-1 | |
|
18571
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
1234 on an active field to invoke its action. Editing an option value |
|
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
1235 changes the text in the buffer; invoke the State button and |
|
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
1236 choose the Set operation to set the option value. |
| 25685 | 1237 Invoke " (if custom-raised-buttons |
| 1238 "`Raised' buttons" | |
| 1239 "Square brackets"))) | |
| 1240 (widget-create 'info-link | |
|
18371
a32f9b2c2e0c
(custom-add-parent-links): New arg INITIAL-STRING.
Richard M. Stallman <rms@gnu.org>
parents:
18370
diff
changeset
|
1241 :tag "Help" |
| 17334 | 1242 :help-echo "Read the online help." |
|
18032
fd3f0a7e79b9
(custom-face-display-set): Define if not defined.
Richard M. Stallman <rms@gnu.org>
parents:
17800
diff
changeset
|
1243 "(emacs)Easy Customization") |
| 17334 | 1244 (widget-insert " for more information.\n\n") |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1245 (message "Creating customization buttons...") |
|
18373
45ef45c34aa4
(custom-buffer-create-internal):
Richard M. Stallman <rms@gnu.org>
parents:
18371
diff
changeset
|
1246 (widget-insert "Operate on everything in this buffer:\n ") |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1247 (widget-create 'push-button |
|
18460
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
1248 :tag "Set for Current Session" |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1249 :help-echo "\ |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1250 Make your editing in this buffer take effect for this session." |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1251 :action (lambda (widget &optional event) |
|
18435
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
1252 (Custom-set))) |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1253 (widget-insert " ") |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1254 (widget-create 'push-button |
|
18460
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
1255 :tag "Save for Future Sessions" |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1256 :help-echo "\ |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1257 Make your editing in this buffer take effect for future Emacs sessions." |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1258 :action (lambda (widget &optional event) |
|
18435
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
1259 (Custom-save))) |
| 18089 | 1260 (if custom-reset-button-menu |
|
18460
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
1261 (progn |
|
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
1262 (widget-insert " ") |
|
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
1263 (widget-create 'push-button |
|
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
1264 :tag "Reset" |
|
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
1265 :help-echo "Show a menu with reset operations." |
|
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
1266 :mouse-down-action (lambda (&rest junk) t) |
|
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
1267 :action (lambda (widget &optional event) |
|
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
1268 (custom-reset event)))) |
|
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
1269 (widget-insert "\n ") |
| 18089 | 1270 (widget-create 'push-button |
| 1271 :tag "Reset" | |
|
18139
ee3c0d09dcd3
Synched with 1.9908.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18131
diff
changeset
|
1272 :help-echo "\ |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1273 Reset all edited text in this buffer to reflect current values." |
|
18435
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
1274 :action 'Custom-reset-current) |
| 18089 | 1275 (widget-insert " ") |
| 1276 (widget-create 'push-button | |
| 1277 :tag "Reset to Saved" | |
|
18139
ee3c0d09dcd3
Synched with 1.9908.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18131
diff
changeset
|
1278 :help-echo "\ |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1279 Reset all values in this buffer to their saved settings." |
|
18435
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
1280 :action 'Custom-reset-saved) |
| 18089 | 1281 (widget-insert " ") |
| 1282 (widget-create 'push-button | |
|
26625
faf989c7a28e
(Custom-reset-standard): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
26451
diff
changeset
|
1283 :tag "Erase Customization" |
|
18139
ee3c0d09dcd3
Synched with 1.9908.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18131
diff
changeset
|
1284 :help-echo "\ |
|
26625
faf989c7a28e
(Custom-reset-standard): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
26451
diff
changeset
|
1285 Un-customize all values in this buffer. They get their standard settings." |
|
18435
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
1286 :action 'Custom-reset-standard)) |
|
18373
45ef45c34aa4
(custom-buffer-create-internal):
Richard M. Stallman <rms@gnu.org>
parents:
18371
diff
changeset
|
1287 (widget-insert " ") |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1288 (widget-create 'push-button |
| 25685 | 1289 :tag "Finish" |
| 1290 :help-echo "Bury or kill the buffer." | |
| 1291 :action #'Custom-buffer-done) | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1292 (widget-insert "\n\n") |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1293 (message "Creating customization items...") |
|
28700
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
1294 (buffer-disable-undo) |
| 25685 | 1295 (setq custom-options |
| 17334 | 1296 (if (= (length options) 1) |
| 1297 (mapcar (lambda (entry) | |
| 1298 (widget-create (nth 1 entry) | |
|
18139
ee3c0d09dcd3
Synched with 1.9908.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18131
diff
changeset
|
1299 :documentation-shown t |
| 17334 | 1300 :custom-state 'unknown |
| 1301 :tag (custom-unlispify-tag-name | |
| 1302 (nth 0 entry)) | |
| 1303 :value (nth 0 entry))) | |
| 1304 options) | |
| 1305 (let ((count 0) | |
| 1306 (length (length options))) | |
| 1307 (mapcar (lambda (entry) | |
| 1308 (prog2 | |
|
22538
2649d061d370
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
22348
diff
changeset
|
1309 (message "Creating customization items ...%2d%%" |
| 17334 | 1310 (/ (* 100.0 count) length)) |
| 1311 (widget-create (nth 1 entry) | |
| 1312 :tag (custom-unlispify-tag-name | |
| 1313 (nth 0 entry)) | |
| 1314 :value (nth 0 entry)) | |
| 1315 (setq count (1+ count)) | |
| 1316 (unless (eq (preceding-char) ?\n) | |
| 1317 (widget-insert "\n")) | |
| 1318 (widget-insert "\n"))) | |
| 1319 options)))) | |
| 1320 (unless (eq (preceding-char) ?\n) | |
| 1321 (widget-insert "\n")) | |
|
22538
2649d061d370
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
22348
diff
changeset
|
1322 (message "Creating customization items ...%2d%%done" 100) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1323 (unless (eq custom-buffer-style 'tree) |
|
28700
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
1324 (mapc 'custom-magic-reset custom-options)) |
| 17334 | 1325 (message "Creating customization setup...") |
| 1326 (widget-setup) | |
|
28700
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
1327 (buffer-enable-undo) |
| 17334 | 1328 (goto-char (point-min)) |
| 1329 (message "Creating customization buffer...done")) | |
| 1330 | |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1331 ;;; The Tree Browser. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1332 |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1333 ;;;###autoload |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1334 (defun customize-browse (&optional group) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1335 "Create a tree browser for the customize hierarchy." |
|
18812
82c80b23fa9d
(custom-unlispify-remove-prefixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18669
diff
changeset
|
1336 (interactive) |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1337 (unless group |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1338 (setq group 'emacs)) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1339 (let ((name "*Customize Browser*")) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1340 (kill-buffer (get-buffer-create name)) |
|
22332
7ad747c6c5a9
(customize-group, customize-group-other-window)
Karl Heuer <kwzh@gnu.org>
parents:
22068
diff
changeset
|
1341 (pop-to-buffer (get-buffer-create name))) |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1342 (custom-mode) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1343 (widget-insert "\ |
|
18812
82c80b23fa9d
(custom-unlispify-remove-prefixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18669
diff
changeset
|
1344 Square brackets show active fields; type RET or click mouse-1 |
|
82c80b23fa9d
(custom-unlispify-remove-prefixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
18669
diff
changeset
|
1345 on an active field to invoke its action. |
|
18856
03eeb83520d8
(custom-group-value-create) <tree>: Don't distinguish
Richard M. Stallman <rms@gnu.org>
parents:
18812
diff
changeset
|
1346 Invoke [+] below to expand a group, and [-] to collapse an expanded group.\n") |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1347 (if custom-browse-only-groups |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1348 (widget-insert "\ |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1349 Invoke the [Group] button below to edit that item in another window.\n\n") |
| 25685 | 1350 (widget-insert "Invoke the ") |
| 1351 (widget-create 'item | |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1352 :format "%t" |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1353 :tag "[Group]" |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1354 :tag-glyph "folder") |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1355 (widget-insert ", ") |
| 25685 | 1356 (widget-create 'item |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1357 :format "%t" |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1358 :tag "[Face]" |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1359 :tag-glyph "face") |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1360 (widget-insert ", and ") |
| 25685 | 1361 (widget-create 'item |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1362 :format "%t" |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1363 :tag "[Option]" |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1364 :tag-glyph "option") |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1365 (widget-insert " buttons below to edit that |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1366 item in another window.\n\n")) |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1367 (let ((custom-buffer-style 'tree)) |
| 25685 | 1368 (widget-create 'custom-group |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1369 :custom-last t |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1370 :custom-state 'unknown |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1371 :tag (custom-unlispify-tag-name group) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1372 :value group)) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
1373 (goto-char (point-min))) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1374 |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1375 (define-widget 'custom-browse-visibility 'item |
|
20600
323f33e3e92c
(custom-browse-visibility): Doc fix.
Andreas Schwab <schwab@suse.de>
parents:
20562
diff
changeset
|
1376 "Control visibility of items in the customize tree browser." |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1377 :format "%[[%t]%]" |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1378 :action 'custom-browse-visibility-action) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1379 |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1380 (defun custom-browse-visibility-action (widget &rest ignore) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1381 (let ((custom-buffer-style 'tree)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1382 (custom-toggle-parent widget))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1383 |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1384 (define-widget 'custom-browse-group-tag 'push-button |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1385 "Show parent in other window when activated." |
|
18371
a32f9b2c2e0c
(custom-add-parent-links): New arg INITIAL-STRING.
Richard M. Stallman <rms@gnu.org>
parents:
18370
diff
changeset
|
1386 :tag "Group" |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1387 :tag-glyph "folder" |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1388 :action 'custom-browse-group-tag-action) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1389 |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1390 (defun custom-browse-group-tag-action (widget &rest ignore) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1391 (let ((parent (widget-get widget :parent))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1392 (customize-group-other-window (widget-value parent)))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1393 |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1394 (define-widget 'custom-browse-variable-tag 'push-button |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1395 "Show parent in other window when activated." |
|
18371
a32f9b2c2e0c
(custom-add-parent-links): New arg INITIAL-STRING.
Richard M. Stallman <rms@gnu.org>
parents:
18370
diff
changeset
|
1396 :tag "Option" |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1397 :tag-glyph "option" |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1398 :action 'custom-browse-variable-tag-action) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1399 |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1400 (defun custom-browse-variable-tag-action (widget &rest ignore) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1401 (let ((parent (widget-get widget :parent))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1402 (customize-variable-other-window (widget-value parent)))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1403 |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1404 (define-widget 'custom-browse-face-tag 'push-button |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1405 "Show parent in other window when activated." |
|
18371
a32f9b2c2e0c
(custom-add-parent-links): New arg INITIAL-STRING.
Richard M. Stallman <rms@gnu.org>
parents:
18370
diff
changeset
|
1406 :tag "Face" |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1407 :tag-glyph "face" |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1408 :action 'custom-browse-face-tag-action) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1409 |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1410 (defun custom-browse-face-tag-action (widget &rest ignore) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1411 (let ((parent (widget-get widget :parent))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1412 (customize-face-other-window (widget-value parent)))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1413 |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1414 (defconst custom-browse-alist '((" " "space") |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1415 (" | " "vertical") |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1416 ("-\\ " "top") |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1417 (" |-" "middle") |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1418 (" `-" "bottom"))) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1419 |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1420 (defun custom-browse-insert-prefix (prefix) |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1421 "Insert PREFIX. On XEmacs convert it to line graphics." |
| 25685 | 1422 ;; Fixme: do graphics. |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1423 (if nil ; (string-match "XEmacs" emacs-version) |
| 25685 | 1424 (progn |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1425 (insert "*") |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1426 (while (not (string-equal prefix "")) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1427 (let ((entry (substring prefix 0 3))) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1428 (setq prefix (substring prefix 3)) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1429 (let ((overlay (make-overlay (1- (point)) (point) nil t nil)) |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1430 (name (nth 1 (assoc entry custom-browse-alist)))) |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1431 (overlay-put overlay 'end-glyph (widget-glyph-find name entry)) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1432 (overlay-put overlay 'start-open t) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1433 (overlay-put overlay 'end-open t))))) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1434 (insert prefix))) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1435 |
| 17334 | 1436 ;;; Modification of Basic Widgets. |
| 1437 ;; | |
| 1438 ;; We add extra properties to the basic widgets needed here. This is | |
| 1439 ;; fine, as long as we are careful to stay within out own namespace. | |
| 1440 ;; | |
| 1441 ;; We want simple widgets to be displayed by default, but complex | |
| 1442 ;; widgets to be hidden. | |
| 1443 | |
| 1444 (widget-put (get 'item 'widget-type) :custom-show t) | |
| 1445 (widget-put (get 'editable-field 'widget-type) | |
| 1446 :custom-show (lambda (widget value) | |
| 1447 (let ((pp (pp-to-string value))) | |
| 1448 (cond ((string-match "\n" pp) | |
| 1449 nil) | |
| 1450 ((> (length pp) 40) | |
| 1451 nil) | |
| 1452 (t t))))) | |
| 1453 (widget-put (get 'menu-choice 'widget-type) :custom-show t) | |
| 1454 | |
| 1455 ;;; The `custom-manual' Widget. | |
| 1456 | |
| 1457 (define-widget 'custom-manual 'info-link | |
| 1458 "Link to the manual entry for this customization option." | |
| 1459 :help-echo "Read the manual entry for this option." | |
| 1460 :tag "Manual") | |
| 1461 | |
| 1462 ;;; The `custom-magic' Widget. | |
| 1463 | |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1464 (defgroup custom-magic-faces nil |
|
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1465 "Faces used by the magic button." |
|
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1466 :group 'custom-faces |
|
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1467 :group 'custom-buffer) |
|
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1468 |
| 17334 | 1469 (defface custom-invalid-face '((((class color)) |
| 1470 (:foreground "yellow" :background "red")) | |
| 1471 (t | |
| 1472 (:bold t :italic t :underline t))) | |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1473 "Face used when the customize item is invalid." |
|
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1474 :group 'custom-magic-faces) |
| 17334 | 1475 |
| 1476 (defface custom-rogue-face '((((class color)) | |
| 1477 (:foreground "pink" :background "black")) | |
| 1478 (t | |
| 1479 (:underline t))) | |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1480 "Face used when the customize item is not defined for customization." |
|
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1481 :group 'custom-magic-faces) |
| 17334 | 1482 |
| 25685 | 1483 (defface custom-modified-face '((((class color)) |
| 17334 | 1484 (:foreground "white" :background "blue")) |
| 1485 (t | |
| 1486 (:italic t :bold))) | |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1487 "Face used when the customize item has been modified." |
|
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1488 :group 'custom-magic-faces) |
| 17334 | 1489 |
| 25685 | 1490 (defface custom-set-face '((((class color)) |
| 17334 | 1491 (:foreground "blue" :background "white")) |
| 1492 (t | |
| 1493 (:italic t))) | |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1494 "Face used when the customize item has been set." |
|
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1495 :group 'custom-magic-faces) |
| 17334 | 1496 |
| 25685 | 1497 (defface custom-changed-face '((((class color)) |
| 17334 | 1498 (:foreground "white" :background "blue")) |
| 1499 (t | |
| 1500 (:italic t))) | |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1501 "Face used when the customize item has been changed." |
|
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1502 :group 'custom-magic-faces) |
| 17334 | 1503 |
| 1504 (defface custom-saved-face '((t (:underline t))) | |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1505 "Face used when the customize item has been saved." |
|
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1506 :group 'custom-magic-faces) |
| 17334 | 1507 |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1508 (defconst custom-magic-alist '((nil "#" underline "\ |
| 17334 | 1509 uninitialized, you should not see this.") |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1510 (unknown "?" italic "\ |
| 17334 | 1511 unknown, you should not see this.") |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1512 (hidden "-" default "\ |
|
18362
4655515f51cc
(custom-magic-alist) <hidden>: Don't refer to "dots".
Richard M. Stallman <rms@gnu.org>
parents:
18360
diff
changeset
|
1513 hidden, invoke \"Show\" in the previous line to show." "\ |
|
4655515f51cc
(custom-magic-alist) <hidden>: Don't refer to "dots".
Richard M. Stallman <rms@gnu.org>
parents:
18360
diff
changeset
|
1514 group now hidden, invoke \"Show\", above, to show contents.") |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1515 (invalid "x" custom-invalid-face "\ |
| 18089 | 1516 the value displayed for this %c is invalid and cannot be set.") |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1517 (modified "*" custom-modified-face "\ |
|
18462
0e65e5074881
(custom-magic-alist): Update messages for `modified' and `set' states.
Richard M. Stallman <rms@gnu.org>
parents:
18460
diff
changeset
|
1518 you have edited the value as text, but you have not set the %c." "\ |
|
0e65e5074881
(custom-magic-alist): Update messages for `modified' and `set' states.
Richard M. Stallman <rms@gnu.org>
parents:
18460
diff
changeset
|
1519 you have edited something in this group, but not set it.") |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1520 (set "+" custom-set-face "\ |
|
18462
0e65e5074881
(custom-magic-alist): Update messages for `modified' and `set' states.
Richard M. Stallman <rms@gnu.org>
parents:
18460
diff
changeset
|
1521 you have set this %c, but not saved it for future sessions." "\ |
|
0e65e5074881
(custom-magic-alist): Update messages for `modified' and `set' states.
Richard M. Stallman <rms@gnu.org>
parents:
18460
diff
changeset
|
1522 something in this group has been set, but not saved.") |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1523 (changed ":" custom-changed-face "\ |
| 18089 | 1524 this %c has been changed outside the customize buffer." "\ |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1525 something in this group has been changed outside customize.") |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1526 (saved "!" custom-saved-face "\ |
| 18089 | 1527 this %c has been set and saved." "\ |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1528 something in this group has been set and saved.") |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1529 (rogue "@" custom-rogue-face "\ |
| 18089 | 1530 this %c has not been changed with customize." "\ |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1531 something in this group is not prepared for customization.") |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1532 (standard " " nil "\ |
| 18089 | 1533 this %c is unchanged from its standard setting." "\ |
|
18139
ee3c0d09dcd3
Synched with 1.9908.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18131
diff
changeset
|
1534 visible group members are all at standard settings.")) |
| 17334 | 1535 "Alist of customize option states. |
| 25685 | 1536 Each entry is of the form (STATE MAGIC FACE ITEM-DESC [ GROUP-DESC ]), where |
| 17334 | 1537 |
| 1538 STATE is one of the following symbols: | |
| 1539 | |
| 1540 `nil' | |
| 1541 For internal use, should never occur. | |
| 1542 `unknown' | |
| 1543 For internal use, should never occur. | |
| 1544 `hidden' | |
| 25685 | 1545 This item is not being displayed. |
| 17334 | 1546 `invalid' |
| 1547 This item is modified, but has an invalid form. | |
| 1548 `modified' | |
| 1549 This item is modified, and has a valid form. | |
| 1550 `set' | |
| 1551 This item has been set but not saved. | |
| 1552 `changed' | |
| 1553 The current value of this item has been changed temporarily. | |
| 1554 `saved' | |
| 1555 This item is marked for saving. | |
| 1556 `rogue' | |
| 1557 This item has no customization information. | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1558 `standard' |
|
17641
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
1559 This item is unchanged from the standard setting. |
|
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
1560 |
|
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
1561 MAGIC is a string used to present that state. |
|
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
1562 |
|
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
1563 FACE is a face used to present the state. |
|
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
1564 |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1565 ITEM-DESC is a string describing the state for options. |
|
17641
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
1566 |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1567 GROUP-DESC is a string describing the state for groups. If this is |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1568 left out, ITEM-DESC will be used. |
| 17334 | 1569 |
| 18089 | 1570 The string %c in either description will be replaced with the |
| 1571 category of the item. These are `group'. `option', and `face'. | |
| 1572 | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1573 The list should be sorted most significant first.") |
| 17334 | 1574 |
| 1575 (defcustom custom-magic-show 'long | |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
1576 "If non-nil, show textual description of the state. |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1577 If `long', show a full-line description, not just one word." |
| 17334 | 1578 :type '(choice (const :tag "no" nil) |
|
22600
2f3b4c74e9a1
(custom-magic-show): Use `other' widget type.
Andreas Schwab <schwab@suse.de>
parents:
22538
diff
changeset
|
1579 (const long) |
|
2f3b4c74e9a1
(custom-magic-show): Use `other' widget type.
Andreas Schwab <schwab@suse.de>
parents:
22538
diff
changeset
|
1580 (other :tag "short" short)) |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1581 :group 'custom-buffer) |
| 17334 | 1582 |
| 18089 | 1583 (defcustom custom-magic-show-hidden '(option face) |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1584 "Control whether the State button is shown for hidden items. |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1585 The value should be a list with the custom categories where the State |
| 18089 | 1586 button should be visible. Possible categories are `group', `option', |
| 1587 and `face'." | |
| 1588 :type '(set (const group) (const option) (const face)) | |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1589 :group 'custom-buffer) |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
1590 |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1591 (defcustom custom-magic-show-button nil |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1592 "Show a \"magic\" button indicating the state of each customization option." |
| 17334 | 1593 :type 'boolean |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
1594 :group 'custom-buffer) |
| 17334 | 1595 |
| 1596 (define-widget 'custom-magic 'default | |
| 1597 "Show and manipulate state for a customization option." | |
| 1598 :format "%v" | |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1599 :action 'widget-parent-action |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1600 :notify 'ignore |
| 17334 | 1601 :value-get 'ignore |
| 1602 :value-create 'custom-magic-value-create | |
| 1603 :value-delete 'widget-children-value-delete) | |
| 1604 | |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1605 (defun widget-magic-mouse-down-action (widget &optional event) |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1606 ;; Non-nil unless hidden. |
| 25685 | 1607 (not (eq (widget-get (widget-get (widget-get widget :parent) :parent) |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1608 :custom-state) |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1609 'hidden))) |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1610 |
| 17334 | 1611 (defun custom-magic-value-create (widget) |
| 28130 | 1612 "Create compact status report for WIDGET." |
| 17334 | 1613 (let* ((parent (widget-get widget :parent)) |
| 1614 (state (widget-get parent :custom-state)) | |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
1615 (hidden (eq state 'hidden)) |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1616 (entry (assq state custom-magic-alist)) |
| 17334 | 1617 (magic (nth 1 entry)) |
| 1618 (face (nth 2 entry)) | |
| 18089 | 1619 (category (widget-get parent :custom-category)) |
| 1620 (text (or (and (eq category 'group) | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1621 (nth 4 entry)) |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1622 (nth 3 entry))) |
|
19040
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
1623 (form (widget-get parent :custom-form)) |
| 17334 | 1624 children) |
| 18089 | 1625 (while (string-match "\\`\\(.*\\)%c\\(.*\\)\\'" text) |
| 25685 | 1626 (setq text (concat (match-string 1 text) |
| 18089 | 1627 (symbol-name category) |
| 1628 (match-string 2 text)))) | |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
1629 (when (and custom-magic-show |
| 18089 | 1630 (or (not hidden) |
| 1631 (memq category custom-magic-show-hidden))) | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1632 (insert " ") |
|
18367
f4682a047be1
(custom-magic-value-create):
Richard M. Stallman <rms@gnu.org>
parents:
18364
diff
changeset
|
1633 (when (and (eq category 'group) |
|
f4682a047be1
(custom-magic-value-create):
Richard M. Stallman <rms@gnu.org>
parents:
18364
diff
changeset
|
1634 (not (and (eq custom-buffer-style 'links) |
|
f4682a047be1
(custom-magic-value-create):
Richard M. Stallman <rms@gnu.org>
parents:
18364
diff
changeset
|
1635 (> (widget-get parent :custom-level) 1)))) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1636 (insert-char ?\ (* custom-buffer-indent |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1637 (widget-get parent :custom-level)))) |
| 25685 | 1638 (push (widget-create-child-and-convert |
| 1639 widget 'choice-item | |
| 18087 | 1640 :help-echo "Change the state of this item." |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
1641 :format (if hidden "%t" "%[%t%]") |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1642 :button-prefix 'widget-push-button-prefix |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
1643 :button-suffix 'widget-push-button-suffix |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1644 :mouse-down-action 'widget-magic-mouse-down-action |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1645 :tag "State") |
| 17334 | 1646 children) |
| 1647 (insert ": ") | |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1648 (let ((start (point))) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1649 (if (eq custom-magic-show 'long) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1650 (insert text) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1651 (insert (symbol-name state))) |
|
19040
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
1652 (cond ((eq form 'lisp) |
|
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
1653 (insert " (lisp)")) |
|
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
1654 ((eq form 'mismatch) |
|
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
1655 (insert " (mismatch)"))) |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1656 (put-text-property start (point) 'face 'custom-state-face)) |
| 17334 | 1657 (insert "\n")) |
|
18367
f4682a047be1
(custom-magic-value-create):
Richard M. Stallman <rms@gnu.org>
parents:
18364
diff
changeset
|
1658 (when (and (eq category 'group) |
|
f4682a047be1
(custom-magic-value-create):
Richard M. Stallman <rms@gnu.org>
parents:
18364
diff
changeset
|
1659 (not (and (eq custom-buffer-style 'links) |
|
f4682a047be1
(custom-magic-value-create):
Richard M. Stallman <rms@gnu.org>
parents:
18364
diff
changeset
|
1660 (> (widget-get parent :custom-level) 1)))) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1661 (insert-char ?\ (* custom-buffer-indent |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1662 (widget-get parent :custom-level)))) |
| 17334 | 1663 (when custom-magic-show-button |
| 1664 (when custom-magic-show | |
| 1665 (let ((indent (widget-get parent :indent))) | |
| 1666 (when indent | |
| 1667 (insert-char ? indent)))) | |
| 25685 | 1668 (push (widget-create-child-and-convert |
| 1669 widget 'choice-item | |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1670 :mouse-down-action 'widget-magic-mouse-down-action |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1671 :button-face face |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
1672 :button-prefix "" |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
1673 :button-suffix "" |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1674 :help-echo "Change the state." |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
1675 :format (if hidden "%t" "%[%t%]") |
|
19040
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
1676 :tag (if (memq form '(lisp mismatch)) |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1677 (concat "(" magic ")") |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1678 (concat "[" magic "]"))) |
| 17334 | 1679 children) |
| 1680 (insert " ")) | |
| 1681 (widget-put widget :children children))) | |
| 1682 | |
| 1683 (defun custom-magic-reset (widget) | |
| 1684 "Redraw the :custom-magic property of WIDGET." | |
| 1685 (let ((magic (widget-get widget :custom-magic))) | |
| 1686 (widget-value-set magic (widget-value magic)))) | |
| 1687 | |
| 1688 ;;; The `custom' Widget. | |
| 1689 | |
| 25685 | 1690 (defface custom-button-face |
| 1691 '((((type x) (class color)) ; Like default modeline | |
| 1692 (:box (:line-width 2 :style released-button) :background "lightgrey")) | |
|
28245
6896ac619ba9
(custom-button-face) [w32]: Use same face as x.
Jason Rumney <jasonr@gnu.org>
parents:
28172
diff
changeset
|
1693 (((type w32) (class color)) ; Like default modeline |
|
6896ac619ba9
(custom-button-face) [w32]: Use same face as x.
Jason Rumney <jasonr@gnu.org>
parents:
28172
diff
changeset
|
1694 (:box (:line-width 2 :style released-button) :background "lightgrey")) |
| 25685 | 1695 (t |
| 1696 nil)) | |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1697 "Face used for buttons in customization buffers." |
| 25685 | 1698 :version "21.1" |
| 1699 :group 'custom-faces) | |
| 1700 | |
| 1701 (defface custom-button-pressed-face | |
| 1702 '((((type x) (class color)) | |
| 1703 (:box (:line-width 2 :style pressed-button) :background "lightgrey")) | |
|
28245
6896ac619ba9
(custom-button-face) [w32]: Use same face as x.
Jason Rumney <jasonr@gnu.org>
parents:
28172
diff
changeset
|
1704 (((type w32) (class color)) |
|
6896ac619ba9
(custom-button-face) [w32]: Use same face as x.
Jason Rumney <jasonr@gnu.org>
parents:
28172
diff
changeset
|
1705 (:box (:line-width 2 :style pressed-button) :background "lightgrey")) |
| 25685 | 1706 (t |
| 1707 (:inverse-video t))) | |
| 1708 "Face used for buttons in customization buffers." | |
| 1709 :version "21.1" | |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1710 :group 'custom-faces) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1711 |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1712 (defface custom-documentation-face nil |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1713 "Face used for documentation strings in customization buffers." |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1714 :group 'custom-faces) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1715 |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1716 (defface custom-state-face '((((class color) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1717 (background dark)) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1718 (:foreground "lime green")) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1719 (((class color) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1720 (background light)) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1721 (:foreground "dark green")) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1722 (t nil)) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1723 "Face used for State descriptions in the customize buffer." |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1724 :group 'custom-faces) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1725 |
| 17334 | 1726 (define-widget 'custom 'default |
| 1727 "Customize a user option." | |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1728 :format "%v" |
| 17334 | 1729 :convert-widget 'custom-convert-widget |
| 1730 :notify 'custom-notify | |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1731 :custom-prefix "" |
| 17334 | 1732 :custom-level 1 |
| 1733 :custom-state 'hidden | |
| 1734 :documentation-property 'widget-subclass-responsibility | |
| 1735 :value-create 'widget-subclass-responsibility | |
| 1736 :value-delete 'widget-children-value-delete | |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1737 :value-get 'widget-value-value-get |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1738 :validate 'widget-children-validate |
| 17334 | 1739 :match (lambda (widget value) (symbolp value))) |
| 1740 | |
| 1741 (defun custom-convert-widget (widget) | |
| 28130 | 1742 "Initialize :value and :tag from :args in WIDGET." |
| 17334 | 1743 (let ((args (widget-get widget :args))) |
| 25685 | 1744 (when args |
| 17334 | 1745 (widget-put widget :value (widget-apply widget |
| 1746 :value-to-internal (car args))) | |
| 1747 (widget-put widget :tag (custom-unlispify-tag-name (car args))) | |
| 1748 (widget-put widget :args nil))) | |
| 1749 widget) | |
| 1750 | |
| 1751 (defun custom-notify (widget &rest args) | |
| 1752 "Keep track of changes." | |
| 18090 | 1753 (let ((state (widget-get widget :custom-state))) |
| 1754 (unless (eq state 'modified) | |
| 1755 (unless (memq state '(nil unknown hidden)) | |
| 1756 (widget-put widget :custom-state 'modified)) | |
| 1757 (custom-magic-reset widget) | |
| 1758 (apply 'widget-default-notify widget args)))) | |
| 17334 | 1759 |
| 1760 (defun custom-redraw (widget) | |
| 1761 "Redraw WIDGET with current settings." | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1762 (let ((line (count-lines (point-min) (point))) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1763 (column (current-column)) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1764 (pos (point)) |
| 17334 | 1765 (from (marker-position (widget-get widget :from))) |
| 1766 (to (marker-position (widget-get widget :to)))) | |
| 1767 (save-excursion | |
| 1768 (widget-value-set widget (widget-value widget)) | |
| 1769 (custom-redraw-magic widget)) | |
| 1770 (when (and (>= pos from) (<= pos to)) | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1771 (condition-case nil |
| 25685 | 1772 (progn |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1773 (if (> column 0) |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1774 (goto-line line) |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
1775 (goto-line (1+ line))) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1776 (move-to-column column)) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1777 (error nil))))) |
| 17334 | 1778 |
| 1779 (defun custom-redraw-magic (widget) | |
| 1780 "Redraw WIDGET state with current settings." | |
| 25685 | 1781 (while widget |
| 17334 | 1782 (let ((magic (widget-get widget :custom-magic))) |
| 25685 | 1783 (cond (magic |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1784 (widget-value-set magic (widget-value magic)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1785 (when (setq widget (widget-get widget :group)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1786 (custom-group-state-update widget))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1787 (t |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1788 (setq widget nil))))) |
| 17334 | 1789 (widget-setup)) |
| 1790 | |
| 1791 (defun custom-show (widget value) | |
| 1792 "Non-nil if WIDGET should be shown with VALUE by default." | |
| 1793 (let ((show (widget-get widget :custom-show))) | |
| 1794 (cond ((null show) | |
| 1795 nil) | |
| 1796 ((eq t show) | |
| 1797 t) | |
| 1798 (t | |
| 1799 (funcall show widget value))))) | |
| 1800 | |
| 17415 | 1801 (defvar custom-load-recursion nil |
| 1802 "Hack to avoid recursive dependencies.") | |
| 1803 | |
| 17334 | 1804 (defun custom-load-symbol (symbol) |
| 1805 "Load all dependencies for SYMBOL." | |
| 17415 | 1806 (unless custom-load-recursion |
| 25685 | 1807 (let ((custom-load-recursion t) |
| 17415 | 1808 (loads (get symbol 'custom-loads)) |
| 1809 load) | |
| 1810 (while loads | |
| 1811 (setq load (car loads) | |
| 1812 loads (cdr loads)) | |
| 1813 (cond ((symbolp load) | |
| 1814 (condition-case nil | |
| 1815 (require load) | |
| 1816 (error nil))) | |
|
18059
fef9a6fc0655
(custom-load-symbol): Simplify previous change.
Richard M. Stallman <rms@gnu.org>
parents:
18053
diff
changeset
|
1817 ;; Don't reload a file already loaded. |
|
19040
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
1818 ((and (boundp 'preloaded-file-list) |
|
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
1819 (member load preloaded-file-list))) |
|
18086
dbae3eb8b351
(customize-option): Renamed from custom-variable.
Richard M. Stallman <rms@gnu.org>
parents:
18085
diff
changeset
|
1820 ((assoc load load-history)) |
|
18059
fef9a6fc0655
(custom-load-symbol): Simplify previous change.
Richard M. Stallman <rms@gnu.org>
parents:
18053
diff
changeset
|
1821 ((assoc (locate-library load) load-history)) |
| 17415 | 1822 (t |
| 1823 (condition-case nil | |
|
18059
fef9a6fc0655
(custom-load-symbol): Simplify previous change.
Richard M. Stallman <rms@gnu.org>
parents:
18053
diff
changeset
|
1824 ;; Without this, we would load cus-edit recursively. |
|
fef9a6fc0655
(custom-load-symbol): Simplify previous change.
Richard M. Stallman <rms@gnu.org>
parents:
18053
diff
changeset
|
1825 ;; We are still loading it when we call this, |
|
fef9a6fc0655
(custom-load-symbol): Simplify previous change.
Richard M. Stallman <rms@gnu.org>
parents:
18053
diff
changeset
|
1826 ;; and it is not in load-history yet. |
|
fef9a6fc0655
(custom-load-symbol): Simplify previous change.
Richard M. Stallman <rms@gnu.org>
parents:
18053
diff
changeset
|
1827 (or (equal load "cus-edit") |
|
fef9a6fc0655
(custom-load-symbol): Simplify previous change.
Richard M. Stallman <rms@gnu.org>
parents:
18053
diff
changeset
|
1828 (load-library load)) |
| 17415 | 1829 (error nil)))))))) |
| 17334 | 1830 |
| 1831 (defun custom-load-widget (widget) | |
| 1832 "Load all dependencies for WIDGET." | |
| 1833 (custom-load-symbol (widget-value widget))) | |
| 1834 | |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1835 (defun custom-unloaded-symbol-p (symbol) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1836 "Return non-nil if the dependencies of SYMBOL has not yet been loaded." |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1837 (let ((found nil) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1838 (loads (get symbol 'custom-loads)) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1839 load) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1840 (while loads |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1841 (setq load (car loads) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1842 loads (cdr loads)) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1843 (cond ((symbolp load) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1844 (unless (featurep load) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1845 (setq found t))) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1846 ((assoc load load-history)) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1847 ((assoc (locate-library load) load-history) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1848 (message nil)) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1849 (t |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1850 (setq found t)))) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1851 found)) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1852 |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1853 (defun custom-unloaded-widget-p (widget) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1854 "Return non-nil if the dependencies of WIDGET has not yet been loaded." |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1855 (custom-unloaded-symbol-p (widget-value widget))) |
|
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1856 |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1857 (defun custom-toggle-hide (widget) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1858 "Toggle visibility of WIDGET." |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
1859 (custom-load-widget widget) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1860 (let ((state (widget-get widget :custom-state))) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1861 (cond ((memq state '(invalid modified)) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1862 (error "There are unset changes")) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1863 ((eq state 'hidden) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1864 (widget-put widget :custom-state 'unknown)) |
| 25685 | 1865 (t |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
1866 (widget-put widget :documentation-shown nil) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1867 (widget-put widget :custom-state 'hidden))) |
|
18258
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
1868 (custom-redraw widget) |
|
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
1869 (widget-setup))) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
1870 |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
1871 (defun custom-toggle-parent (widget &rest ignore) |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
1872 "Toggle visibility of parent of WIDGET." |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
1873 (custom-toggle-hide (widget-get widget :parent))) |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
1874 |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1875 (defun custom-add-see-also (widget &optional prefix) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1876 "Add `See also ...' to WIDGET if there are any links. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1877 Insert PREFIX first if non-nil." |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1878 (let* ((symbol (widget-get widget :value)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1879 (links (get symbol 'custom-links)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1880 (many (> (length links) 2)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1881 (buttons (widget-get widget :buttons)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1882 (indent (widget-get widget :indent))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1883 (when links |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1884 (when indent |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1885 (insert-char ?\ indent)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1886 (when prefix |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1887 (insert prefix)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1888 (insert "See also ") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1889 (while links |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1890 (push (widget-create-child-and-convert widget (car links)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1891 buttons) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1892 (setq links (cdr links)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1893 (cond ((null links) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1894 (insert ".\n")) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1895 ((null (cdr links)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1896 (if many |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1897 (insert ", and ") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1898 (insert " and "))) |
| 25685 | 1899 (t |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1900 (insert ", ")))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1901 (widget-put widget :buttons buttons)))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1902 |
|
18371
a32f9b2c2e0c
(custom-add-parent-links): New arg INITIAL-STRING.
Richard M. Stallman <rms@gnu.org>
parents:
18370
diff
changeset
|
1903 (defun custom-add-parent-links (widget &optional initial-string) |
|
a32f9b2c2e0c
(custom-add-parent-links): New arg INITIAL-STRING.
Richard M. Stallman <rms@gnu.org>
parents:
18370
diff
changeset
|
1904 "Add \"Parent groups: ...\" to WIDGET if the group has parents. |
|
a32f9b2c2e0c
(custom-add-parent-links): New arg INITIAL-STRING.
Richard M. Stallman <rms@gnu.org>
parents:
18370
diff
changeset
|
1905 The value if non-nil if any parents were found. |
|
a32f9b2c2e0c
(custom-add-parent-links): New arg INITIAL-STRING.
Richard M. Stallman <rms@gnu.org>
parents:
18370
diff
changeset
|
1906 If INITIAL-STRING is non-nil, use that rather than \"Parent groups:\"." |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1907 (let ((name (widget-value widget)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1908 (type (widget-type widget)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1909 (buttons (widget-get widget :buttons)) |
|
18370
74558272517b
(custom-group-value-create): Use group-visibility widget.
Richard M. Stallman <rms@gnu.org>
parents:
18368
diff
changeset
|
1910 (start (point)) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1911 found) |
|
18371
a32f9b2c2e0c
(custom-add-parent-links): New arg INITIAL-STRING.
Richard M. Stallman <rms@gnu.org>
parents:
18370
diff
changeset
|
1912 (insert (or initial-string "Parent groups:")) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1913 (mapatoms (lambda (symbol) |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1914 (let ((entry (assq name (get symbol 'custom-group)))) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1915 (when (eq (nth 1 entry) type) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1916 (insert " ") |
| 25685 | 1917 (push (widget-create-child-and-convert |
| 1918 widget 'custom-group-link | |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1919 :tag (custom-unlispify-tag-name symbol) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1920 symbol) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1921 buttons) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
1922 (setq found t))))) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1923 (widget-put widget :buttons buttons) |
|
18370
74558272517b
(custom-group-value-create): Use group-visibility widget.
Richard M. Stallman <rms@gnu.org>
parents:
18368
diff
changeset
|
1924 (if found |
|
74558272517b
(custom-group-value-create): Use group-visibility widget.
Richard M. Stallman <rms@gnu.org>
parents:
18368
diff
changeset
|
1925 (insert "\n") |
|
74558272517b
(custom-group-value-create): Use group-visibility widget.
Richard M. Stallman <rms@gnu.org>
parents:
18368
diff
changeset
|
1926 (delete-region start (point))) |
|
74558272517b
(custom-group-value-create): Use group-visibility widget.
Richard M. Stallman <rms@gnu.org>
parents:
18368
diff
changeset
|
1927 found)) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
1928 |
| 25685 | 1929 ;;; The `custom-comment' Widget. |
| 1930 | |
| 1931 ;; like the editable field | |
| 1932 (defface custom-comment-face '((((class grayscale color) | |
| 1933 (background light)) | |
| 1934 (:background "gray85")) | |
| 1935 (((class grayscale color) | |
| 1936 (background dark)) | |
| 1937 (:background "dim gray")) | |
| 1938 (t | |
| 1939 (:italic t))) | |
| 1940 "Face used for comments on variables or faces" | |
| 1941 :version "21.1" | |
| 1942 :group 'custom-faces) | |
| 1943 | |
| 1944 ;; like font-lock-comment-face | |
| 1945 (defface custom-comment-tag-face | |
| 1946 '((((class color) (background dark)) (:foreground "gray80")) | |
| 1947 (((class color) (background light)) (:foreground "blue4")) | |
| 1948 (((class grayscale) (background light)) | |
| 1949 (:foreground "DimGray" :bold t :italic t)) | |
| 1950 (((class grayscale) (background dark)) | |
| 1951 (:foreground "LightGray" :bold t :italic t)) | |
| 1952 (t (:bold t))) | |
| 1953 "Face used for variables or faces comment tags" | |
| 1954 :group 'custom-faces) | |
| 1955 | |
| 1956 (define-widget 'custom-comment 'string | |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
1957 "User comment." |
| 25685 | 1958 :tag "Comment" |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
1959 :help-echo "Edit a comment here." |
| 25685 | 1960 :sample-face 'custom-comment-tag-face |
| 1961 :value-face 'custom-comment-face | |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
1962 :shown nil |
|
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
1963 :create 'custom-comment-create) |
| 25685 | 1964 |
| 1965 (defun custom-comment-create (widget) | |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
1966 (let* ((null-comment (equal "" (widget-value widget)))) |
|
25847
f54121af02c8
(custom-comment-create): Fill :from and :to slots
Dave Love <fx@gnu.org>
parents:
25840
diff
changeset
|
1967 (if (or (widget-get (widget-get widget :parent) :comment-shown) |
|
f54121af02c8
(custom-comment-create): Fill :from and :to slots
Dave Love <fx@gnu.org>
parents:
25840
diff
changeset
|
1968 (not null-comment)) |
|
f54121af02c8
(custom-comment-create): Fill :from and :to slots
Dave Love <fx@gnu.org>
parents:
25840
diff
changeset
|
1969 (widget-default-create widget) |
|
f54121af02c8
(custom-comment-create): Fill :from and :to slots
Dave Love <fx@gnu.org>
parents:
25840
diff
changeset
|
1970 ;; `widget-default-delete' expects markers in these slots -- |
|
f54121af02c8
(custom-comment-create): Fill :from and :to slots
Dave Love <fx@gnu.org>
parents:
25840
diff
changeset
|
1971 ;; maybe it shouldn't. |
|
f54121af02c8
(custom-comment-create): Fill :from and :to slots
Dave Love <fx@gnu.org>
parents:
25840
diff
changeset
|
1972 (widget-put widget :from (point-marker)) |
|
f54121af02c8
(custom-comment-create): Fill :from and :to slots
Dave Love <fx@gnu.org>
parents:
25840
diff
changeset
|
1973 (widget-put widget :to (point-marker))))) |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
1974 |
|
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
1975 (defun custom-comment-hide (widget) |
|
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
1976 (widget-put (widget-get widget :parent) :comment-shown nil)) |
| 25685 | 1977 |
| 1978 ;; Those functions are for the menu. WIDGET is NOT the comment widget. It's | |
| 1979 ;; the global custom one | |
| 1980 (defun custom-comment-show (widget) | |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
1981 (widget-put widget :comment-shown t) |
|
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
1982 (custom-redraw widget) |
|
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
1983 (widget-setup)) |
| 25685 | 1984 |
| 1985 (defun custom-comment-invisible-p (widget) | |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
1986 (let ((val (widget-value (widget-get widget :comment-widget)))) |
|
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
1987 (and (equal "" val) |
|
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
1988 (not (widget-get widget :comment-shown))))) |
| 25685 | 1989 |
| 17334 | 1990 ;;; The `custom-variable' Widget. |
| 1991 | |
| 28130 | 1992 ;; When this was underlined blue, users confused it with a |
| 1993 ;; Mosaic-style hyperlink... | |
|
28172
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
1994 (defface custom-variable-tag-face |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
1995 `((((class color) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
1996 (background dark)) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
1997 (:foreground "light blue" :bold t :family "helv" |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
1998 :height ,(let ((height (face-attribute 'default :height))) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
1999 (if (numberp height) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2000 (floor height 0.9) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2001 height)))) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2002 (((class color) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2003 (background light)) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2004 (:foreground "blue" :family "helv" :bold t |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2005 :height ,(let ((height (face-attribute 'default :height))) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2006 (if (numberp height) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2007 (floor height 0.9) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2008 height)))) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2009 (t (:bold t))) |
| 17334 | 2010 "Face used for unpushable variable tags." |
| 17415 | 2011 :group 'custom-faces) |
| 17334 | 2012 |
| 2013 (defface custom-variable-button-face '((t (:underline t :bold t))) | |
| 2014 "Face used for pushable variable tags." | |
| 17415 | 2015 :group 'custom-faces) |
| 17334 | 2016 |
|
20411
089ca3e66e6d
(custom-unlispify-remove-prefixes): Reference to
Karl Heuer <kwzh@gnu.org>
parents:
20398
diff
changeset
|
2017 (defcustom custom-variable-default-form 'edit |
|
089ca3e66e6d
(custom-unlispify-remove-prefixes): Reference to
Karl Heuer <kwzh@gnu.org>
parents:
20398
diff
changeset
|
2018 "Default form of displaying variable values." |
|
089ca3e66e6d
(custom-unlispify-remove-prefixes): Reference to
Karl Heuer <kwzh@gnu.org>
parents:
20398
diff
changeset
|
2019 :type '(choice (const edit) |
|
089ca3e66e6d
(custom-unlispify-remove-prefixes): Reference to
Karl Heuer <kwzh@gnu.org>
parents:
20398
diff
changeset
|
2020 (const lisp)) |
|
21669
9861518505cb
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
21649
diff
changeset
|
2021 :group 'custom-buffer |
|
9861518505cb
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
21649
diff
changeset
|
2022 :version "20.3") |
|
20411
089ca3e66e6d
(custom-unlispify-remove-prefixes): Reference to
Karl Heuer <kwzh@gnu.org>
parents:
20398
diff
changeset
|
2023 |
| 17334 | 2024 (define-widget 'custom-variable 'custom |
| 2025 "Customize variable." | |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2026 :format "%v" |
| 17334 | 2027 :help-echo "Set or reset this variable." |
| 2028 :documentation-property 'variable-documentation | |
| 18089 | 2029 :custom-category 'option |
| 17334 | 2030 :custom-state nil |
| 2031 :custom-menu 'custom-variable-menu-create | |
|
20411
089ca3e66e6d
(custom-unlispify-remove-prefixes): Reference to
Karl Heuer <kwzh@gnu.org>
parents:
20398
diff
changeset
|
2032 :custom-form nil ; defaults to value of `custom-variable-default-form' |
| 17334 | 2033 :value-create 'custom-variable-value-create |
| 2034 :action 'custom-variable-action | |
| 2035 :custom-set 'custom-variable-set | |
| 2036 :custom-save 'custom-variable-save | |
| 2037 :custom-reset-current 'custom-redraw | |
| 2038 :custom-reset-saved 'custom-variable-reset-saved | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2039 :custom-reset-standard 'custom-variable-reset-standard) |
| 17334 | 2040 |
| 17415 | 2041 (defun custom-variable-type (symbol) |
| 2042 "Return a widget suitable for editing the value of SYMBOL. | |
| 25685 | 2043 If SYMBOL has a `custom-type' property, use that. |
| 17415 | 2044 Otherwise, look up symbol in `custom-guess-type-alist'." |
| 2045 (let* ((type (or (get symbol 'custom-type) | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2046 (and (not (get symbol 'standard-value)) |
| 17415 | 2047 (custom-guess-type symbol)) |
| 2048 'sexp)) | |
| 2049 (options (get symbol 'custom-options)) | |
| 2050 (tmp (if (listp type) | |
|
17534
a5cf59eee84b
(custom-variable-type): Use copy-sequence, not copy-list.
Richard M. Stallman <rms@gnu.org>
parents:
17521
diff
changeset
|
2051 (copy-sequence type) |
| 17415 | 2052 (list type)))) |
| 2053 (when options | |
| 2054 (widget-put tmp :options options)) | |
| 2055 tmp)) | |
| 2056 | |
| 17334 | 2057 (defun custom-variable-value-create (widget) |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
2058 "Here is where you edit the variable's value." |
| 17334 | 2059 (custom-load-widget widget) |
|
20411
089ca3e66e6d
(custom-unlispify-remove-prefixes): Reference to
Karl Heuer <kwzh@gnu.org>
parents:
20398
diff
changeset
|
2060 (unless (widget-get widget :custom-form) |
|
089ca3e66e6d
(custom-unlispify-remove-prefixes): Reference to
Karl Heuer <kwzh@gnu.org>
parents:
20398
diff
changeset
|
2061 (widget-put widget :custom-form custom-variable-default-form)) |
| 17334 | 2062 (let* ((buttons (widget-get widget :buttons)) |
| 2063 (children (widget-get widget :children)) | |
| 2064 (form (widget-get widget :custom-form)) | |
| 2065 (state (widget-get widget :custom-state)) | |
| 2066 (symbol (widget-get widget :value)) | |
| 2067 (tag (widget-get widget :tag)) | |
| 17415 | 2068 (type (custom-variable-type symbol)) |
| 17334 | 2069 (conv (widget-convert type)) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2070 (get (or (get symbol 'custom-get) 'default-value)) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2071 (prefix (widget-get widget :custom-prefix)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2072 (last (widget-get widget :custom-last)) |
| 17334 | 2073 (value (if (default-boundp symbol) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2074 (funcall get symbol) |
| 17334 | 2075 (widget-get conv :value)))) |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
2076 ;; If the widget is new, the child determines whether it is hidden. |
| 17334 | 2077 (cond (state) |
| 2078 ((custom-show type value) | |
| 2079 (setq state 'unknown)) | |
| 2080 (t | |
| 2081 (setq state 'hidden))) | |
| 2082 ;; If we don't know the state, see if we need to edit it in lisp form. | |
| 2083 (when (eq state 'unknown) | |
| 2084 (unless (widget-apply conv :match value) | |
| 2085 ;; (widget-apply (widget-convert type) :match value) | |
|
19040
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
2086 (setq form 'mismatch))) |
| 17334 | 2087 ;; Now we can create the child widget. |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2088 (cond ((eq custom-buffer-style 'tree) |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
2089 (insert prefix (if last " `--- " " |--- ")) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2090 (push (widget-create-child-and-convert |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
2091 widget 'custom-browse-variable-tag) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2092 buttons) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2093 (insert " " tag "\n") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2094 (widget-put widget :buttons buttons)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2095 ((eq state 'hidden) |
| 17334 | 2096 ;; Indicate hidden value. |
| 25685 | 2097 (push (widget-create-child-and-convert |
| 17334 | 2098 widget 'item |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2099 :format "%{%t%}: " |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
2100 :sample-face 'custom-variable-tag-face |
| 17334 | 2101 :tag tag |
| 2102 :parent widget) | |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2103 buttons) |
| 25685 | 2104 (push (widget-create-child-and-convert |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2105 widget 'visibility |
|
18258
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
2106 :help-echo "Show the value of this option." |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2107 :action 'custom-toggle-parent |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2108 nil) |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2109 buttons)) |
|
19040
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
2110 ((memq form '(lisp mismatch)) |
| 17334 | 2111 ;; In lisp mode edit the saved value when possible. |
| 2112 (let* ((value (cond ((get symbol 'saved-value) | |
| 2113 (car (get symbol 'saved-value))) | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2114 ((get symbol 'standard-value) |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2115 (car (get symbol 'standard-value))) |
| 17334 | 2116 ((default-boundp symbol) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2117 (custom-quote (funcall get symbol))) |
| 17334 | 2118 (t |
| 2119 (custom-quote (widget-get conv :value)))))) | |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2120 (insert (symbol-name symbol) ": ") |
| 25685 | 2121 (push (widget-create-child-and-convert |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2122 widget 'visibility |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2123 :help-echo "Hide the value of this option." |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2124 :action 'custom-toggle-parent |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2125 t) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2126 buttons) |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2127 (insert " ") |
| 25685 | 2128 (push (widget-create-child-and-convert |
| 2129 widget 'sexp | |
| 17334 | 2130 :button-face 'custom-variable-button-face |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2131 :format "%v" |
| 17334 | 2132 :tag (symbol-name symbol) |
| 2133 :parent widget | |
| 2134 :value value) | |
| 2135 children))) | |
| 2136 (t | |
| 2137 ;; Edit mode. | |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2138 (let* ((format (widget-get type :format)) |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2139 tag-format value-format) |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2140 (unless (string-match ":" format) |
|
19883
519eab181c36
(custom-face-menu): Use custom-face-save-command. not custom-face-save.
Richard M. Stallman <rms@gnu.org>
parents:
19823
diff
changeset
|
2141 (error "Bad format")) |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2142 (setq tag-format (substring format 0 (match-end 0))) |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2143 (setq value-format (substring format (match-end 0))) |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2144 (push (widget-create-child-and-convert |
| 25685 | 2145 widget 'item |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2146 :format tag-format |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2147 :action 'custom-tag-action |
|
18258
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
2148 :help-echo "Change value of this option." |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2149 :mouse-down-action 'custom-tag-mouse-down-action |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2150 :button-face 'custom-variable-button-face |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
2151 :sample-face 'custom-variable-tag-face |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2152 tag) |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2153 buttons) |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2154 (insert " ") |
| 25685 | 2155 (push (widget-create-child-and-convert |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
2156 widget 'visibility |
|
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
2157 :help-echo "Hide the value of this option." |
|
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
2158 :action 'custom-toggle-parent |
|
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
2159 t) |
|
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
2160 buttons) |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2161 (push (widget-create-child-and-convert |
| 25685 | 2162 widget type |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2163 :format value-format |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2164 :value value) |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2165 children)))) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2166 (unless (eq custom-buffer-style 'tree) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2167 (unless (eq (preceding-char) ?\n) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2168 (widget-insert "\n")) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2169 ;; Create the magic button. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2170 (let ((magic (widget-create-child-and-convert |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2171 widget 'custom-magic nil))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2172 (widget-put widget :custom-magic magic) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2173 (push magic buttons)) |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
2174 ;; ### NOTE: this is ugly!!!! I need to update the :buttons property |
| 25685 | 2175 ;; before the call to `widget-default-format-handler'. Otherwise, I |
| 2176 ;; loose my current `buttons'. This function shouldn't be called like | |
| 2177 ;; this anyway. The doc string widget should be added like the others. | |
| 2178 ;; --dv | |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2179 (widget-put widget :buttons buttons) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2180 ;; Insert documentation. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2181 (widget-default-format-handler widget ?h) |
| 25685 | 2182 |
| 2183 ;; The comment field | |
| 2184 (unless (eq state 'hidden) | |
| 2185 (let* ((comment (get symbol 'variable-comment)) | |
| 2186 (comment-widget | |
| 2187 (widget-create-child-and-convert | |
| 2188 widget 'custom-comment | |
| 2189 :parent widget | |
| 2190 :value (or comment "")))) | |
| 2191 (widget-put widget :comment-widget comment-widget) | |
| 2192 ;; Don't push it !!! Custom assumes that the first child is the | |
| 2193 ;; value one. | |
| 2194 (setq children (append children (list comment-widget))))) | |
| 2195 ;; Update the rest of the properties properties. | |
| 2196 (widget-put widget :custom-form form) | |
| 2197 (widget-put widget :children children) | |
| 2198 ;; Now update the state. | |
| 2199 (if (eq state 'hidden) | |
| 2200 (widget-put widget :custom-state state) | |
| 2201 (custom-variable-state-set widget)) | |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2202 ;; See also. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2203 (unless (eq state 'hidden) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2204 (when (eq (widget-get widget :custom-level) 1) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2205 (custom-add-parent-links widget)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2206 (custom-add-see-also widget))))) |
| 17334 | 2207 |
|
18067
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2208 (defun custom-tag-action (widget &rest args) |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2209 "Pass :action to first child of WIDGET's parent." |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2210 (apply 'widget-apply (car (widget-get (widget-get widget :parent) :children)) |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2211 :action args)) |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2212 |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2213 (defun custom-tag-mouse-down-action (widget &rest args) |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2214 "Pass :mouse-down-action to first child of WIDGET's parent." |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2215 (apply 'widget-apply (car (widget-get (widget-get widget :parent) :children)) |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2216 :mouse-down-action args)) |
|
0e2aa3b58e16
Synched with version 1.9901.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18059
diff
changeset
|
2217 |
| 17334 | 2218 (defun custom-variable-state-set (widget) |
| 2219 "Set the state of WIDGET." | |
| 2220 (let* ((symbol (widget-value widget)) | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2221 (get (or (get symbol 'custom-get) 'default-value)) |
| 17334 | 2222 (value (if (default-boundp symbol) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2223 (funcall get symbol) |
| 17334 | 2224 (widget-get widget :value))) |
| 25685 | 2225 (comment (get symbol 'variable-comment)) |
| 17334 | 2226 tmp |
| 25685 | 2227 temp |
| 2228 (state (cond ((progn (setq tmp (get symbol 'customized-value)) | |
| 2229 (setq temp | |
| 2230 (get symbol 'customized-variable-comment)) | |
| 2231 (or tmp temp)) | |
| 17334 | 2232 (if (condition-case nil |
| 25685 | 2233 (and (equal value (eval (car tmp))) |
| 2234 (equal comment temp)) | |
| 17334 | 2235 (error nil)) |
| 2236 'set | |
| 2237 'changed)) | |
| 25685 | 2238 ((progn (setq tmp (get symbol 'saved-value)) |
| 2239 (setq temp (get symbol 'saved-variable-comment)) | |
| 2240 (or tmp temp)) | |
| 17334 | 2241 (if (condition-case nil |
| 25685 | 2242 (and (equal value (eval (car tmp))) |
| 2243 (equal comment temp)) | |
| 17334 | 2244 (error nil)) |
| 2245 'saved | |
| 2246 'changed)) | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2247 ((setq tmp (get symbol 'standard-value)) |
| 17334 | 2248 (if (condition-case nil |
| 25685 | 2249 (and (equal value (eval (car tmp))) |
| 2250 (equal comment nil)) | |
| 17334 | 2251 (error nil)) |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2252 'standard |
| 17334 | 2253 'changed)) |
| 2254 (t 'rogue)))) | |
| 2255 (widget-put widget :custom-state state))) | |
| 2256 | |
| 25685 | 2257 (defvar custom-variable-menu |
|
18460
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
2258 '(("Set for Current Session" custom-variable-set |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2259 (lambda (widget) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2260 (eq (widget-get widget :custom-state) 'modified))) |
|
18460
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
2261 ("Save for Future Sessions" custom-variable-save |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2262 (lambda (widget) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2263 (memq (widget-get widget :custom-state) '(modified set changed rogue)))) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2264 ("Reset to Current" custom-redraw |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2265 (lambda (widget) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2266 (and (default-boundp (widget-value widget)) |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
2267 (memq (widget-get widget :custom-state) '(modified changed))))) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2268 ("Reset to Saved" custom-variable-reset-saved |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2269 (lambda (widget) |
| 25685 | 2270 (and (or (get (widget-value widget) 'saved-value) |
| 2271 (get (widget-value widget) 'saved-variable-comment)) | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2272 (memq (widget-get widget :custom-state) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2273 '(modified set changed rogue))))) |
|
26625
faf989c7a28e
(Custom-reset-standard): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
26451
diff
changeset
|
2274 ("Erase Customization" custom-variable-reset-standard |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2275 (lambda (widget) |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2276 (and (get (widget-value widget) 'standard-value) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2277 (memq (widget-get widget :custom-state) |
|
18258
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
2278 '(modified set changed saved rogue))))) |
|
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
2279 ("---" ignore ignore) |
| 25685 | 2280 ("Add Comment" custom-comment-show custom-comment-invisible-p) |
| 2281 ("---" ignore ignore) | |
| 2282 ("Don't show as Lisp expression" custom-variable-edit | |
|
18258
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
2283 (lambda (widget) |
|
19040
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
2284 (eq (widget-get widget :custom-form) 'lisp))) |
|
19823
0c1b4a44db76
(custom-variable-save): Fixed doc string.
Richard M. Stallman <rms@gnu.org>
parents:
19822
diff
changeset
|
2285 ("Show initial Lisp expression" custom-variable-edit-lisp |
|
18258
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
2286 (lambda (widget) |
|
19040
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
2287 (eq (widget-get widget :custom-form) 'edit)))) |
| 17334 | 2288 "Alist of actions for the `custom-variable' widget. |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2289 Each entry has the form (NAME ACTION FILTER) where NAME is the name of |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2290 the menu entry, ACTION is the function to call on the widget when the |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2291 menu is selected, and FILTER is a predicate which takes a `custom-variable' |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2292 widget as an argument, and returns non-nil if ACTION is valid on that |
|
26625
faf989c7a28e
(Custom-reset-standard): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
26451
diff
changeset
|
2293 widget. If FILTER is nil, ACTION is always valid.") |
| 17334 | 2294 |
| 2295 (defun custom-variable-action (widget &optional event) | |
| 2296 "Show the menu for `custom-variable' WIDGET. | |
| 2297 Optional EVENT is the location for the menu." | |
| 2298 (if (eq (widget-get widget :custom-state) 'hidden) | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2299 (custom-toggle-hide widget) |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
2300 (unless (eq (widget-get widget :custom-state) 'modified) |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
2301 (custom-variable-state-set widget)) |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
2302 (custom-redraw-magic widget) |
| 17334 | 2303 (let* ((completion-ignore-case t) |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2304 (answer (widget-choose (concat "Operation on " |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2305 (custom-unlispify-tag-name |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2306 (widget-get widget :value))) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2307 (custom-menu-filter custom-variable-menu |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2308 widget) |
| 17334 | 2309 event))) |
| 2310 (if answer | |
| 2311 (funcall answer widget))))) | |
| 2312 | |
| 2313 (defun custom-variable-edit (widget) | |
| 2314 "Edit value of WIDGET." | |
| 2315 (widget-put widget :custom-state 'unknown) | |
| 2316 (widget-put widget :custom-form 'edit) | |
| 2317 (custom-redraw widget)) | |
| 2318 | |
| 2319 (defun custom-variable-edit-lisp (widget) | |
| 28130 | 2320 "Edit the Lisp representation of the value of WIDGET." |
| 17334 | 2321 (widget-put widget :custom-state 'unknown) |
| 2322 (widget-put widget :custom-form 'lisp) | |
| 2323 (custom-redraw widget)) | |
| 2324 | |
| 2325 (defun custom-variable-set (widget) | |
| 2326 "Set the current value for the variable being edited by WIDGET." | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2327 (let* ((form (widget-get widget :custom-form)) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2328 (state (widget-get widget :custom-state)) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2329 (child (car (widget-get widget :children))) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2330 (symbol (widget-value widget)) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2331 (set (or (get symbol 'custom-set) 'set-default)) |
| 25685 | 2332 (comment-widget (widget-get widget :comment-widget)) |
| 2333 (comment (widget-value comment-widget)) | |
| 2334 val) | |
| 17334 | 2335 (cond ((eq state 'hidden) |
|
19883
519eab181c36
(custom-face-menu): Use custom-face-save-command. not custom-face-save.
Richard M. Stallman <rms@gnu.org>
parents:
19823
diff
changeset
|
2336 (error "Cannot set hidden variable")) |
| 17334 | 2337 ((setq val (widget-apply child :validate)) |
| 2338 (goto-char (widget-get val :from)) | |
| 2339 (error "%s" (widget-get val :error))) | |
|
19040
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
2340 ((memq form '(lisp mismatch)) |
| 25685 | 2341 (when (equal comment "") |
| 2342 (setq comment nil) | |
| 2343 ;; Make the comment invisible by hand if it's empty | |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
2344 (custom-comment-hide comment-widget)) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2345 (funcall set symbol (eval (setq val (widget-value child)))) |
| 25685 | 2346 (put symbol 'customized-value (list val)) |
| 2347 (put symbol 'variable-comment comment) | |
| 2348 (put symbol 'customized-variable-comment comment)) | |
| 17334 | 2349 (t |
| 25685 | 2350 (when (equal comment "") |
| 2351 (setq comment nil) | |
| 2352 ;; Make the comment invisible by hand if it's empty | |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
2353 (custom-comment-hide comment-widget)) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2354 (funcall set symbol (setq val (widget-value child))) |
| 25685 | 2355 (put symbol 'customized-value (list (custom-quote val))) |
| 2356 (put symbol 'variable-comment comment) | |
| 2357 (put symbol 'customized-variable-comment comment))) | |
| 17334 | 2358 (custom-variable-state-set widget) |
| 2359 (custom-redraw-magic widget))) | |
| 2360 | |
| 2361 (defun custom-variable-save (widget) | |
|
19823
0c1b4a44db76
(custom-variable-save): Fixed doc string.
Richard M. Stallman <rms@gnu.org>
parents:
19822
diff
changeset
|
2362 "Set and save the value for the variable being edited by WIDGET." |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2363 (let* ((form (widget-get widget :custom-form)) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2364 (state (widget-get widget :custom-state)) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2365 (child (car (widget-get widget :children))) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2366 (symbol (widget-value widget)) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2367 (set (or (get symbol 'custom-set) 'set-default)) |
| 25685 | 2368 (comment-widget (widget-get widget :comment-widget)) |
| 2369 (comment (widget-value comment-widget)) | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2370 val) |
| 17334 | 2371 (cond ((eq state 'hidden) |
|
19883
519eab181c36
(custom-face-menu): Use custom-face-save-command. not custom-face-save.
Richard M. Stallman <rms@gnu.org>
parents:
19823
diff
changeset
|
2372 (error "Cannot set hidden variable")) |
| 17334 | 2373 ((setq val (widget-apply child :validate)) |
| 2374 (goto-char (widget-get val :from)) | |
| 2375 (error "%s" (widget-get val :error))) | |
|
19040
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
2376 ((memq form '(lisp mismatch)) |
| 25685 | 2377 (when (equal comment "") |
| 2378 (setq comment nil) | |
| 2379 ;; Make the comment invisible by hand if it's empty | |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
2380 (custom-comment-hide comment-widget)) |
| 17334 | 2381 (put symbol 'saved-value (list (widget-value child))) |
| 25685 | 2382 (funcall set symbol (eval (widget-value child))) |
| 2383 (put symbol 'variable-comment comment) | |
| 2384 (put symbol 'saved-variable-comment comment)) | |
| 17334 | 2385 (t |
| 25685 | 2386 (when (equal comment "") |
| 2387 (setq comment nil) | |
| 2388 ;; Make the comment invisible by hand if it's empty | |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
2389 (custom-comment-hide comment-widget)) |
| 25685 | 2390 (put symbol 'saved-value |
| 2391 (list (custom-quote (widget-value child)))) | |
| 2392 (funcall set symbol (widget-value child)) | |
| 2393 (put symbol 'variable-comment comment) | |
| 2394 (put symbol 'saved-variable-comment comment))) | |
| 17334 | 2395 (put symbol 'customized-value nil) |
| 25685 | 2396 (put symbol 'customized-variable-comment nil) |
| 17334 | 2397 (custom-save-all) |
| 2398 (custom-variable-state-set widget) | |
| 2399 (custom-redraw-magic widget))) | |
| 2400 | |
| 2401 (defun custom-variable-reset-saved (widget) | |
| 2402 "Restore the saved value for the variable being edited by WIDGET." | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2403 (let* ((symbol (widget-value widget)) |
| 25685 | 2404 (set (or (get symbol 'custom-set) 'set-default)) |
| 2405 (comment-widget (widget-get widget :comment-widget)) | |
| 2406 (value (get symbol 'saved-value)) | |
| 2407 (comment (get symbol 'saved-variable-comment))) | |
| 2408 (cond ((or value comment) | |
| 2409 (put symbol 'variable-comment comment) | |
| 2410 (condition-case nil | |
| 2411 (funcall set symbol (eval (car value))) | |
| 2412 (error nil))) | |
| 2413 (t | |
| 2414 (error "No saved value for %s" symbol))) | |
| 17334 | 2415 (put symbol 'customized-value nil) |
| 25685 | 2416 (put symbol 'customized-variable-comment nil) |
| 17334 | 2417 (widget-put widget :custom-state 'unknown) |
| 25685 | 2418 ;; This call will possibly make the comment invisible |
| 17334 | 2419 (custom-redraw widget))) |
| 2420 | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2421 (defun custom-variable-reset-standard (widget) |
|
26625
faf989c7a28e
(Custom-reset-standard): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
26451
diff
changeset
|
2422 "Restore the standard setting for the variable being edited by WIDGET. |
|
faf989c7a28e
(Custom-reset-standard): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
26451
diff
changeset
|
2423 This operation eliminates any saved setting for the variable, |
|
faf989c7a28e
(Custom-reset-standard): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
26451
diff
changeset
|
2424 restoring it to the state of a variable that has never been customized." |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2425 (let* ((symbol (widget-value widget)) |
| 25685 | 2426 (set (or (get symbol 'custom-set) 'set-default)) |
| 2427 (comment-widget (widget-get widget :comment-widget))) | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2428 (if (get symbol 'standard-value) |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2429 (funcall set symbol (eval (car (get symbol 'standard-value)))) |
|
17641
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
2430 (error "No standard setting known for %S" symbol)) |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
2431 (put symbol 'variable-comment nil) |
| 17334 | 2432 (put symbol 'customized-value nil) |
| 25685 | 2433 (put symbol 'customized-variable-comment nil) |
| 2434 (when (or (get symbol 'saved-value) (get symbol 'saved-variable-comment)) | |
| 17334 | 2435 (put symbol 'saved-value nil) |
| 25685 | 2436 (put symbol 'saved-variable-comment nil) |
| 17334 | 2437 (custom-save-all)) |
| 2438 (widget-put widget :custom-state 'unknown) | |
| 25685 | 2439 ;; This call will possibly make the comment invisible |
| 17334 | 2440 (custom-redraw widget))) |
| 2441 | |
| 2442 ;;; The `custom-face-edit' Widget. | |
| 2443 | |
| 2444 (define-widget 'custom-face-edit 'checklist | |
| 2445 "Edit face attributes." | |
| 2446 :format "%t: %v" | |
| 2447 :tag "Attributes" | |
| 2448 :extra-offset 12 | |
| 25685 | 2449 :button-args '(:help-echo "Control whether this attribute has any effect.") |
| 17334 | 2450 :args (mapcar (lambda (att) |
| 25685 | 2451 (list 'group |
| 17334 | 2452 :inline t |
| 2453 :sibling-args (widget-get (nth 1 att) :sibling-args) | |
| 25685 | 2454 (list 'const :format "" :value (nth 0 att)) |
| 17334 | 2455 (nth 1 att))) |
| 2456 custom-face-attributes)) | |
| 2457 | |
| 2458 ;;; The `custom-display' Widget. | |
| 2459 | |
| 2460 (define-widget 'custom-display 'menu-choice | |
| 2461 "Select a display type." | |
| 2462 :tag "Display" | |
| 2463 :value t | |
| 2464 :help-echo "Specify frames where the face attributes should be used." | |
| 2465 :args '((const :tag "all" t) | |
| 2466 (checklist | |
| 2467 :offset 0 | |
| 2468 :extra-offset 9 | |
| 2469 :args ((group :sibling-args (:help-echo "\ | |
| 2470 Only match the specified window systems.") | |
| 2471 (const :format "Type: " | |
| 2472 type) | |
| 2473 (checklist :inline t | |
| 2474 :offset 0 | |
| 2475 (const :format "X " | |
| 2476 :sibling-args (:help-echo "\ | |
| 2477 The X11 Window System.") | |
| 2478 x) | |
| 2479 (const :format "PM " | |
| 2480 :sibling-args (:help-echo "\ | |
| 2481 OS/2 Presentation Manager.") | |
| 2482 pm) | |
|
19684
d5378da3dd73
(custom-display): Use w32 instead of win32.
Geoff Voelker <voelker@cs.washington.edu>
parents:
19316
diff
changeset
|
2483 (const :format "W32 " |
| 17334 | 2484 :sibling-args (:help-echo "\ |
|
19684
d5378da3dd73
(custom-display): Use w32 instead of win32.
Geoff Voelker <voelker@cs.washington.edu>
parents:
19316
diff
changeset
|
2485 Windows NT/9X.") |
|
d5378da3dd73
(custom-display): Use w32 instead of win32.
Geoff Voelker <voelker@cs.washington.edu>
parents:
19316
diff
changeset
|
2486 w32) |
| 17334 | 2487 (const :format "DOS " |
| 2488 :sibling-args (:help-echo "\ | |
| 2489 Plain MS-DOS.") | |
| 2490 pc) | |
| 2491 (const :format "TTY%n" | |
| 2492 :sibling-args (:help-echo "\ | |
| 2493 Plain text terminals.") | |
| 2494 tty))) | |
| 2495 (group :sibling-args (:help-echo "\ | |
| 2496 Only match the frames with the specified color support.") | |
| 2497 (const :format "Class: " | |
| 2498 class) | |
| 2499 (checklist :inline t | |
| 2500 :offset 0 | |
| 2501 (const :format "Color " | |
| 2502 :sibling-args (:help-echo "\ | |
| 2503 Match color frames.") | |
| 2504 color) | |
| 2505 (const :format "Grayscale " | |
| 2506 :sibling-args (:help-echo "\ | |
| 2507 Match grayscale frames.") | |
| 2508 grayscale) | |
| 2509 (const :format "Monochrome%n" | |
| 2510 :sibling-args (:help-echo "\ | |
| 2511 Match frames with no color support.") | |
| 2512 mono))) | |
| 2513 (group :sibling-args (:help-echo "\ | |
| 2514 Only match frames with the specified intensity.") | |
| 2515 (const :format "\ | |
| 2516 Background brightness: " | |
| 2517 background) | |
| 2518 (checklist :inline t | |
| 2519 :offset 0 | |
| 2520 (const :format "Light " | |
| 2521 :sibling-args (:help-echo "\ | |
| 2522 Match frames with light backgrounds.") | |
| 2523 light) | |
| 2524 (const :format "Dark\n" | |
| 2525 :sibling-args (:help-echo "\ | |
| 2526 Match frames with dark backgrounds.") | |
| 2527 dark))))))) | |
| 2528 | |
| 2529 ;;; The `custom-face' Widget. | |
| 2530 | |
|
28172
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2531 (defface custom-face-tag-face |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2532 `((t (:bold t :family "helv" |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2533 :height ,(let ((height (face-attribute 'default :height))) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2534 (if (numberp height) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2535 (floor height 0.9) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2536 height))))) |
| 17334 | 2537 "Face used for face tags." |
| 17415 | 2538 :group 'custom-faces) |
| 17334 | 2539 |
|
20411
089ca3e66e6d
(custom-unlispify-remove-prefixes): Reference to
Karl Heuer <kwzh@gnu.org>
parents:
20398
diff
changeset
|
2540 (defcustom custom-face-default-form 'selected |
|
089ca3e66e6d
(custom-unlispify-remove-prefixes): Reference to
Karl Heuer <kwzh@gnu.org>
parents:
20398
diff
changeset
|
2541 "Default form of displaying face definition." |
|
089ca3e66e6d
(custom-unlispify-remove-prefixes): Reference to
Karl Heuer <kwzh@gnu.org>
parents:
20398
diff
changeset
|
2542 :type '(choice (const all) |
|
089ca3e66e6d
(custom-unlispify-remove-prefixes): Reference to
Karl Heuer <kwzh@gnu.org>
parents:
20398
diff
changeset
|
2543 (const selected) |
|
089ca3e66e6d
(custom-unlispify-remove-prefixes): Reference to
Karl Heuer <kwzh@gnu.org>
parents:
20398
diff
changeset
|
2544 (const lisp)) |
|
21669
9861518505cb
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
21649
diff
changeset
|
2545 :group 'custom-buffer |
|
9861518505cb
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
21649
diff
changeset
|
2546 :version "20.3") |
|
20411
089ca3e66e6d
(custom-unlispify-remove-prefixes): Reference to
Karl Heuer <kwzh@gnu.org>
parents:
20398
diff
changeset
|
2547 |
| 17334 | 2548 (define-widget 'custom-face 'custom |
| 2549 "Customize face." | |
| 2550 :sample-face 'custom-face-tag-face | |
| 2551 :help-echo "Set or reset this face." | |
|
28716
e9fb71a3e51d
(custom-face): Fix parenthesis.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28700
diff
changeset
|
2552 :documentation-property #'face-doc-string |
| 17334 | 2553 :value-create 'custom-face-value-create |
| 2554 :action 'custom-face-action | |
| 18089 | 2555 :custom-category 'face |
|
20411
089ca3e66e6d
(custom-unlispify-remove-prefixes): Reference to
Karl Heuer <kwzh@gnu.org>
parents:
20398
diff
changeset
|
2556 :custom-form nil ; defaults to value of `custom-face-default-form' |
| 17334 | 2557 :custom-set 'custom-face-set |
| 2558 :custom-save 'custom-face-save | |
| 2559 :custom-reset-current 'custom-redraw | |
| 2560 :custom-reset-saved 'custom-face-reset-saved | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2561 :custom-reset-standard 'custom-face-reset-standard |
| 17334 | 2562 :custom-menu 'custom-face-menu-create) |
| 2563 | |
| 25685 | 2564 (define-widget 'custom-face-all 'editable-list |
| 17334 | 2565 "An editable list of display specifications and attributes." |
| 2566 :entry-format "%i %d %v" | |
| 2567 :insert-button-args '(:help-echo "Insert new display specification here.") | |
| 2568 :append-button-args '(:help-echo "Append new display specification here.") | |
| 2569 :delete-button-args '(:help-echo "Delete this display specification.") | |
| 2570 :args '((group :format "%v" custom-display custom-face-edit))) | |
| 2571 | |
| 2572 (defconst custom-face-all (widget-convert 'custom-face-all) | |
| 2573 "Converted version of the `custom-face-all' widget.") | |
| 2574 | |
| 2575 (define-widget 'custom-display-unselected 'item | |
| 2576 "A display specification that doesn't match the selected display." | |
| 2577 :match 'custom-display-unselected-match) | |
| 2578 | |
| 2579 (defun custom-display-unselected-match (widget value) | |
| 2580 "Non-nil if VALUE is an unselected display specification." | |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
2581 (not (face-spec-set-match-display value (selected-frame)))) |
| 17334 | 2582 |
| 25685 | 2583 (define-widget 'custom-face-selected 'group |
| 17334 | 2584 "Edit the attributes of the selected display in a face specification." |
| 2585 :args '((repeat :format "" | |
| 2586 :inline t | |
| 2587 (group custom-display-unselected sexp)) | |
| 2588 (group (sexp :format "") custom-face-edit) | |
| 2589 (repeat :format "" | |
| 2590 :inline t | |
| 2591 sexp))) | |
| 2592 | |
| 2593 (defconst custom-face-selected (widget-convert 'custom-face-selected) | |
| 2594 "Converted version of the `custom-face-selected' widget.") | |
| 2595 | |
| 2596 (defun custom-face-value-create (widget) | |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2597 "Create a list of the display specifications for WIDGET." |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2598 (let ((buttons (widget-get widget :buttons)) |
| 25685 | 2599 children |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2600 (symbol (widget-get widget :value)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2601 (tag (widget-get widget :tag)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2602 (state (widget-get widget :custom-state)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2603 (begin (point)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2604 (is-last (widget-get widget :custom-last)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2605 (prefix (widget-get widget :custom-prefix))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2606 (unless tag |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2607 (setq tag (prin1-to-string symbol))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2608 (cond ((eq custom-buffer-style 'tree) |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
2609 (insert prefix (if is-last " `--- " " |--- ")) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2610 (push (widget-create-child-and-convert |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
2611 widget 'custom-browse-face-tag) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2612 buttons) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2613 (insert " " tag "\n") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2614 (widget-put widget :buttons buttons)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2615 (t |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2616 ;; Create tag. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2617 (insert tag) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2618 (if (eq custom-buffer-style 'face) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2619 (insert " ") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2620 (widget-specify-sample widget begin (point)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2621 (insert ": ")) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2622 ;; Sample. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2623 (push (widget-create-child-and-convert widget 'item |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2624 :format "(%{%t%})" |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2625 :sample-face symbol |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2626 :tag "sample") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2627 buttons) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2628 ;; Visibility. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2629 (insert " ") |
| 25685 | 2630 (push (widget-create-child-and-convert |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2631 widget 'visibility |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2632 :help-echo "Hide or show this face." |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2633 :action 'custom-toggle-parent |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2634 (not (eq state 'hidden))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2635 buttons) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2636 ;; Magic. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2637 (insert "\n") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2638 (let ((magic (widget-create-child-and-convert |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2639 widget 'custom-magic nil))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2640 (widget-put widget :custom-magic magic) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2641 (push magic buttons)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2642 ;; Update buttons. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2643 (widget-put widget :buttons buttons) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2644 ;; Insert documentation. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2645 (widget-default-format-handler widget ?h) |
| 25685 | 2646 ;; The comment field |
| 2647 (unless (eq state 'hidden) | |
| 2648 (let* ((comment (get symbol 'face-comment)) | |
| 2649 (comment-widget | |
| 2650 (widget-create-child-and-convert | |
| 2651 widget 'custom-comment | |
| 2652 :parent widget | |
| 2653 :value (or comment "")))) | |
| 2654 (widget-put widget :comment-widget comment-widget) | |
| 2655 (push comment-widget children))) | |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2656 ;; See also. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2657 (unless (eq state 'hidden) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2658 (when (eq (widget-get widget :custom-level) 1) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2659 (custom-add-parent-links widget)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2660 (custom-add-see-also widget)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2661 ;; Editor. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2662 (unless (eq (preceding-char) ?\n) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2663 (insert "\n")) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2664 (unless (eq state 'hidden) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2665 (message "Creating face editor...") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2666 (custom-load-widget widget) |
|
20411
089ca3e66e6d
(custom-unlispify-remove-prefixes): Reference to
Karl Heuer <kwzh@gnu.org>
parents:
20398
diff
changeset
|
2667 (unless (widget-get widget :custom-form) |
|
089ca3e66e6d
(custom-unlispify-remove-prefixes): Reference to
Karl Heuer <kwzh@gnu.org>
parents:
20398
diff
changeset
|
2668 (widget-put widget :custom-form custom-face-default-form)) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2669 (let* ((symbol (widget-value widget)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2670 (spec (or (get symbol 'saved-face) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2671 (get symbol 'face-defface-spec) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2672 ;; Attempt to construct it. |
| 25685 | 2673 (list (list t (custom-face-attributes-get |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2674 symbol (selected-frame)))))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2675 (form (widget-get widget :custom-form)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2676 (indent (widget-get widget :indent)) |
|
19097
200ff7e7d620
(custom-face-value-create): Take account
Richard M. Stallman <rms@gnu.org>
parents:
19040
diff
changeset
|
2677 edit) |
|
200ff7e7d620
(custom-face-value-create): Take account
Richard M. Stallman <rms@gnu.org>
parents:
19040
diff
changeset
|
2678 ;; If the user has changed this face in some other way, |
|
200ff7e7d620
(custom-face-value-create): Take account
Richard M. Stallman <rms@gnu.org>
parents:
19040
diff
changeset
|
2679 ;; edit it as the user has specified it. |
|
200ff7e7d620
(custom-face-value-create): Take account
Richard M. Stallman <rms@gnu.org>
parents:
19040
diff
changeset
|
2680 (if (not (face-spec-match-p symbol spec (selected-frame))) |
|
200ff7e7d620
(custom-face-value-create): Take account
Richard M. Stallman <rms@gnu.org>
parents:
19040
diff
changeset
|
2681 (setq spec (list (list t (face-attr-construct symbol (selected-frame)))))) |
|
200ff7e7d620
(custom-face-value-create): Take account
Richard M. Stallman <rms@gnu.org>
parents:
19040
diff
changeset
|
2682 (setq edit (widget-create-child-and-convert |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2683 widget |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2684 (cond ((and (eq form 'selected) |
| 25685 | 2685 (widget-apply custom-face-selected |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2686 :match spec)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2687 (when indent (insert-char ?\ indent)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2688 'custom-face-selected) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2689 ((and (not (eq form 'lisp)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2690 (widget-apply custom-face-all |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2691 :match spec)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2692 'custom-face-all) |
| 25685 | 2693 (t |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2694 (when indent (insert-char ?\ indent)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2695 'sexp)) |
|
19097
200ff7e7d620
(custom-face-value-create): Take account
Richard M. Stallman <rms@gnu.org>
parents:
19040
diff
changeset
|
2696 :value spec)) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2697 (custom-face-state-set widget) |
| 25685 | 2698 (push edit children) |
| 2699 (widget-put widget :children children)) | |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2700 (message "Creating face editor...done")))))) |
| 17334 | 2701 |
| 25685 | 2702 (defvar custom-face-menu |
|
18571
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
2703 '(("Set for Current Session" custom-face-set) |
|
19883
519eab181c36
(custom-face-menu): Use custom-face-save-command. not custom-face-save.
Richard M. Stallman <rms@gnu.org>
parents:
19823
diff
changeset
|
2704 ("Save for Future Sessions" custom-face-save-command) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2705 ("Reset to Saved" custom-face-reset-saved |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2706 (lambda (widget) |
| 25685 | 2707 (or (get (widget-value widget) 'saved-face) |
| 2708 (get (widget-value widget) 'saved-face-comment)))) | |
|
26625
faf989c7a28e
(Custom-reset-standard): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
26451
diff
changeset
|
2709 ("Erase Customization" custom-face-reset-standard |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2710 (lambda (widget) |
|
18258
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
2711 (get (widget-value widget) 'face-defface-spec))) |
|
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
2712 ("---" ignore ignore) |
| 25685 | 2713 ("Add Comment" custom-comment-show custom-comment-invisible-p) |
| 2714 ("---" ignore ignore) | |
|
18258
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
2715 ("Show all display specs" custom-face-edit-all |
|
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
2716 (lambda (widget) |
|
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
2717 (not (eq (widget-get widget :custom-form) 'all)))) |
|
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
2718 ("Just current attributes" custom-face-edit-selected |
|
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
2719 (lambda (widget) |
|
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
2720 (not (eq (widget-get widget :custom-form) 'selected)))) |
|
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
2721 ("Show as Lisp expression" custom-face-edit-lisp |
|
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
2722 (lambda (widget) |
|
e83bc8150072
Synched with 1.9920.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18244
diff
changeset
|
2723 (not (eq (widget-get widget :custom-form) 'lisp))))) |
| 17334 | 2724 "Alist of actions for the `custom-face' widget. |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2725 Each entry has the form (NAME ACTION FILTER) where NAME is the name of |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2726 the menu entry, ACTION is the function to call on the widget when the |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2727 menu is selected, and FILTER is a predicate which takes a `custom-face' |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2728 widget as an argument, and returns non-nil if ACTION is valid on that |
|
26625
faf989c7a28e
(Custom-reset-standard): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
26451
diff
changeset
|
2729 widget. If FILTER is nil, ACTION is always valid.") |
| 17334 | 2730 |
| 2731 (defun custom-face-edit-selected (widget) | |
| 2732 "Edit selected attributes of the value of WIDGET." | |
| 2733 (widget-put widget :custom-state 'unknown) | |
| 2734 (widget-put widget :custom-form 'selected) | |
| 2735 (custom-redraw widget)) | |
| 2736 | |
| 2737 (defun custom-face-edit-all (widget) | |
| 2738 "Edit all attributes of the value of WIDGET." | |
| 2739 (widget-put widget :custom-state 'unknown) | |
| 2740 (widget-put widget :custom-form 'all) | |
| 2741 (custom-redraw widget)) | |
| 2742 | |
| 2743 (defun custom-face-edit-lisp (widget) | |
| 28130 | 2744 "Edit the Lisp representation of the value of WIDGET." |
| 17334 | 2745 (widget-put widget :custom-state 'unknown) |
| 2746 (widget-put widget :custom-form 'lisp) | |
| 2747 (custom-redraw widget)) | |
| 2748 | |
| 2749 (defun custom-face-state-set (widget) | |
| 2750 "Set the state of WIDGET." | |
| 25685 | 2751 (let* ((symbol (widget-value widget)) |
| 2752 (comment (get symbol 'face-comment)) | |
| 2753 tmp temp) | |
| 2754 (widget-put widget :custom-state | |
| 2755 (cond ((progn | |
| 2756 (setq tmp (get symbol 'customized-face)) | |
| 2757 (setq temp (get symbol 'customized-face-comment)) | |
| 2758 (or tmp temp)) | |
| 2759 (if (equal temp comment) | |
| 2760 'set | |
| 2761 'changed)) | |
| 2762 ((progn | |
| 2763 (setq tmp (get symbol 'saved-face)) | |
| 2764 (setq temp (get symbol 'saved-face-comment)) | |
| 2765 (or tmp temp)) | |
| 2766 (if (equal temp comment) | |
| 2767 'saved | |
| 2768 'changed)) | |
| 2769 ((get symbol 'face-defface-spec) | |
| 2770 (if (equal comment nil) | |
| 2771 'standard | |
| 2772 'changed)) | |
| 2773 (t | |
| 2774 'rogue))))) | |
| 17334 | 2775 |
| 2776 (defun custom-face-action (widget &optional event) | |
| 2777 "Show the menu for `custom-face' WIDGET. | |
| 2778 Optional EVENT is the location for the menu." | |
| 2779 (if (eq (widget-get widget :custom-state) 'hidden) | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2780 (custom-toggle-hide widget) |
| 17334 | 2781 (let* ((completion-ignore-case t) |
| 2782 (symbol (widget-get widget :value)) | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2783 (answer (widget-choose (concat "Operation on " |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2784 (custom-unlispify-tag-name symbol)) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2785 (custom-menu-filter custom-face-menu |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2786 widget) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
2787 event))) |
| 17334 | 2788 (if answer |
| 2789 (funcall answer widget))))) | |
| 2790 | |
| 2791 (defun custom-face-set (widget) | |
| 2792 "Make the face attributes in WIDGET take effect." | |
| 2793 (let* ((symbol (widget-value widget)) | |
| 2794 (child (car (widget-get widget :children))) | |
| 25685 | 2795 (value (widget-value child)) |
| 2796 (comment-widget (widget-get widget :comment-widget)) | |
| 2797 (comment (widget-value comment-widget))) | |
| 2798 (when (equal comment "") | |
| 2799 (setq comment nil) | |
| 2800 ;; Make the comment invisible by hand if it's empty | |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
2801 (custom-comment-hide comment-widget)) |
| 17334 | 2802 (put symbol 'customized-face value) |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2803 (face-spec-set symbol value) |
| 25685 | 2804 (put symbol 'customized-face-comment comment) |
| 2805 (put symbol 'face-comment comment) | |
| 17334 | 2806 (custom-face-state-set widget) |
| 2807 (custom-redraw-magic widget))) | |
| 2808 | |
|
19883
519eab181c36
(custom-face-menu): Use custom-face-save-command. not custom-face-save.
Richard M. Stallman <rms@gnu.org>
parents:
19823
diff
changeset
|
2809 (defun custom-face-save-command (widget) |
|
519eab181c36
(custom-face-menu): Use custom-face-save-command. not custom-face-save.
Richard M. Stallman <rms@gnu.org>
parents:
19823
diff
changeset
|
2810 "Save in `.emacs' the face attributes in WIDGET." |
|
519eab181c36
(custom-face-menu): Use custom-face-save-command. not custom-face-save.
Richard M. Stallman <rms@gnu.org>
parents:
19823
diff
changeset
|
2811 (custom-face-save widget) |
|
519eab181c36
(custom-face-menu): Use custom-face-save-command. not custom-face-save.
Richard M. Stallman <rms@gnu.org>
parents:
19823
diff
changeset
|
2812 (custom-save-all)) |
|
519eab181c36
(custom-face-menu): Use custom-face-save-command. not custom-face-save.
Richard M. Stallman <rms@gnu.org>
parents:
19823
diff
changeset
|
2813 |
| 17334 | 2814 (defun custom-face-save (widget) |
|
19883
519eab181c36
(custom-face-menu): Use custom-face-save-command. not custom-face-save.
Richard M. Stallman <rms@gnu.org>
parents:
19823
diff
changeset
|
2815 "Prepare for saving WIDGET's face attributes, but don't write `.emacs'." |
| 17334 | 2816 (let* ((symbol (widget-value widget)) |
| 2817 (child (car (widget-get widget :children))) | |
| 25685 | 2818 (value (widget-value child)) |
| 2819 (comment-widget (widget-get widget :comment-widget)) | |
| 2820 (comment (widget-value comment-widget))) | |
| 2821 (when (equal comment "") | |
| 2822 (setq comment nil) | |
| 2823 ;; Make the comment invisible by hand if it's empty | |
|
25824
0d1ba90ad774
(custom-comment): Change widget definition.
Dave Love <fx@gnu.org>
parents:
25685
diff
changeset
|
2824 (custom-comment-hide comment-widget)) |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2825 (face-spec-set symbol value) |
| 17334 | 2826 (put symbol 'saved-face value) |
| 2827 (put symbol 'customized-face nil) | |
| 25685 | 2828 (put symbol 'face-comment comment) |
| 2829 (put symbol 'customized-face-comment nil) | |
| 2830 (put symbol 'saved-face-comment comment) | |
|
20262
c6532008f2a9
(custom-face-save): Save the face.
Karl Heuer <kwzh@gnu.org>
parents:
20174
diff
changeset
|
2831 (custom-save-all) |
| 17334 | 2832 (custom-face-state-set widget) |
| 2833 (custom-redraw-magic widget))) | |
| 2834 | |
| 2835 (defun custom-face-reset-saved (widget) | |
| 2836 "Restore WIDGET to the face's default attributes." | |
| 2837 (let* ((symbol (widget-value widget)) | |
| 2838 (child (car (widget-get widget :children))) | |
| 25685 | 2839 (value (get symbol 'saved-face)) |
| 2840 (comment (get symbol 'saved-face-comment)) | |
| 2841 (comment-widget (widget-get widget :comment-widget))) | |
| 2842 (unless (or value comment) | |
| 17334 | 2843 (error "No saved value for this face")) |
| 2844 (put symbol 'customized-face nil) | |
| 25685 | 2845 (put symbol 'customized-face-comment nil) |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2846 (face-spec-set symbol value) |
| 25685 | 2847 (put symbol 'face-comment comment) |
| 17334 | 2848 (widget-value-set child value) |
| 25685 | 2849 ;; This call manages the comment visibility |
| 2850 (widget-value-set comment-widget (or comment "")) | |
| 17334 | 2851 (custom-face-state-set widget) |
| 2852 (custom-redraw-magic widget))) | |
| 2853 | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2854 (defun custom-face-reset-standard (widget) |
|
26625
faf989c7a28e
(Custom-reset-standard): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
26451
diff
changeset
|
2855 "Restore WIDGET to the face's standard settings. |
|
faf989c7a28e
(Custom-reset-standard): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
26451
diff
changeset
|
2856 This operation eliminates any saved setting for the face, |
|
faf989c7a28e
(Custom-reset-standard): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
26451
diff
changeset
|
2857 restoring it to the state of a face that has never been customized." |
| 17334 | 2858 (let* ((symbol (widget-value widget)) |
| 2859 (child (car (widget-get widget :children))) | |
| 25685 | 2860 (value (get symbol 'face-defface-spec)) |
| 2861 (comment-widget (widget-get widget :comment-widget))) | |
| 17334 | 2862 (unless value |
|
17641
4650d25e48f6
Say "standard settings" instead of "factory settings".
Richard M. Stallman <rms@gnu.org>
parents:
17550
diff
changeset
|
2863 (error "No standard setting for this face")) |
| 17334 | 2864 (put symbol 'customized-face nil) |
| 25685 | 2865 (put symbol 'customized-face-comment nil) |
| 2866 (when (or (get symbol 'saved-face) (get symbol 'saved-face-comment)) | |
| 17334 | 2867 (put symbol 'saved-face nil) |
| 25685 | 2868 (put symbol 'saved-face-comment nil) |
| 17334 | 2869 (custom-save-all)) |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
2870 (face-spec-set symbol value) |
| 25685 | 2871 (put symbol 'face-comment nil) |
| 17334 | 2872 (widget-value-set child value) |
| 25685 | 2873 ;; This call manages the comment visibility |
| 2874 (widget-value-set comment-widget "") | |
| 17334 | 2875 (custom-face-state-set widget) |
| 2876 (custom-redraw-magic widget))) | |
| 2877 | |
| 2878 ;;; The `face' Widget. | |
| 2879 | |
| 2880 (define-widget 'face 'default | |
| 2881 "Select and customize a face." | |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
2882 :convert-widget 'widget-value-convert-widget |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2883 :button-prefix 'widget-push-button-prefix |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2884 :button-suffix 'widget-push-button-suffix |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2885 :format "%t: %[select face%] %v" |
| 17334 | 2886 :tag "Face" |
| 2887 :value 'default | |
| 2888 :value-create 'widget-face-value-create | |
| 2889 :value-delete 'widget-face-value-delete | |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
2890 :value-get 'widget-value-value-get |
|
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
2891 :validate 'widget-children-validate |
| 17334 | 2892 :action 'widget-face-action |
|
28612
0051d3178111
(custom-face, face): Unquote the lambda.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28568
diff
changeset
|
2893 :match (lambda (widget value) (symbolp value))) |
| 17334 | 2894 |
| 2895 (defun widget-face-value-create (widget) | |
| 28130 | 2896 "Create a `custom-face' child." |
| 17334 | 2897 (let* ((symbol (widget-value widget)) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2898 (custom-buffer-style 'face) |
| 17334 | 2899 (child (widget-create-child-and-convert |
| 2900 widget 'custom-face | |
| 2901 :custom-level nil | |
| 2902 :value symbol))) | |
| 2903 (custom-magic-reset child) | |
| 2904 (setq custom-options (cons child custom-options)) | |
| 2905 (widget-put widget :children (list child)))) | |
| 2906 | |
| 2907 (defun widget-face-value-delete (widget) | |
| 28130 | 2908 "Remove the child from the options." |
| 17334 | 2909 (let ((child (car (widget-get widget :children)))) |
| 2910 (setq custom-options (delq child custom-options)) | |
| 2911 (widget-children-value-delete widget))) | |
| 2912 | |
| 2913 (defvar face-history nil | |
| 2914 "History of entered face names.") | |
| 2915 | |
| 2916 (defun widget-face-action (widget &optional event) | |
| 2917 "Prompt for a face." | |
| 2918 (let ((answer (completing-read "Face: " | |
| 2919 (mapcar (lambda (face) | |
| 2920 (list (symbol-name face))) | |
| 2921 (face-list)) | |
| 25685 | 2922 nil nil nil |
| 17334 | 2923 'face-history))) |
| 2924 (unless (zerop (length answer)) | |
| 2925 (widget-value-set widget (intern answer)) | |
| 2926 (widget-apply widget :notify widget event) | |
| 2927 (widget-setup)))) | |
| 2928 | |
| 2929 ;;; The `hook' Widget. | |
| 2930 | |
| 2931 (define-widget 'hook 'list | |
| 2932 "A emacs lisp hook" | |
|
19040
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
2933 :value-to-internal (lambda (widget value) |
|
19886
539d06d1f0da
(customize-group): Handle groups not yet loaded.
Richard M. Stallman <rms@gnu.org>
parents:
19883
diff
changeset
|
2934 (if (and value (symbolp value)) |
|
19040
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
2935 (list value) |
|
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
2936 value)) |
|
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
2937 :match (lambda (widget value) |
|
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
2938 (or (symbolp value) |
|
20174
e1ca1fe89e6e
(hook): Use `widget-group-match' instead of
Karl Heuer <kwzh@gnu.org>
parents:
20100
diff
changeset
|
2939 (widget-group-match widget value))) |
| 28130 | 2940 ;; Avoid adding undefined functions to the hook, especially for |
| 2941 ;; things like `find-file-hook' or even more basic ones, to avoid | |
| 2942 ;; chaos. | |
| 2943 :set (lambda (symbol value) | |
|
28310
9ba6478b7a27
(hook): Use `dolist' instead of CL's `mapc'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28245
diff
changeset
|
2944 (dolist (elt value) |
|
9ba6478b7a27
(hook): Use `dolist' instead of CL's `mapc'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28245
diff
changeset
|
2945 (if (fboundp elt) |
|
9ba6478b7a27
(hook): Use `dolist' instead of CL's `mapc'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28245
diff
changeset
|
2946 (add-hook symbol elt)))) |
| 17334 | 2947 :convert-widget 'custom-hook-convert-widget |
| 2948 :tag "Hook") | |
| 2949 | |
| 2950 (defun custom-hook-convert-widget (widget) | |
|
27250
807fc106b24c
(custom-hook-convert-widget): Fix comment.
Gerd Moellmann <gerd@gnu.org>
parents:
26803
diff
changeset
|
2951 ;; Handle `:options'. |
| 17334 | 2952 (let* ((options (widget-get widget :options)) |
| 25685 | 2953 (other `(editable-list :inline t |
| 17334 | 2954 :entry-format "%i %d%v" |
| 2955 (function :format " %v"))) | |
| 2956 (args (if options | |
| 2957 (list `(checklist :inline t | |
| 2958 ,@(mapcar (lambda (entry) | |
| 2959 `(function-item ,entry)) | |
| 2960 options)) | |
| 2961 other) | |
| 2962 (list other)))) | |
| 2963 (widget-put widget :args args) | |
| 2964 widget)) | |
| 2965 | |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2966 ;;; The `custom-group-link' Widget. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2967 |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2968 (define-widget 'custom-group-link 'link |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2969 "Show parent in other window when activated." |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
2970 :help-echo "Create customization buffer for this group." |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2971 :action 'custom-group-link-action) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2972 |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2973 (defun custom-group-link-action (widget &rest ignore) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2974 (customize-group (widget-value widget))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
2975 |
| 17334 | 2976 ;;; The `custom-group' Widget. |
| 2977 | |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
2978 (defcustom custom-group-tag-faces nil |
| 17334 | 2979 ;; In XEmacs, this ought to play games with font size. |
| 25685 | 2980 ;; Fixme: make it do so in Emacs. |
| 17334 | 2981 "Face used for group tags. |
| 2982 The first member is used for level 1 groups, the second for level 2, | |
| 2983 and so forth. The remaining group tags are shown with | |
| 2984 `custom-group-tag-face'." | |
| 2985 :type '(repeat face) | |
| 17415 | 2986 :group 'custom-faces) |
| 17334 | 2987 |
|
28172
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2988 (defface custom-group-tag-face-1 |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2989 `((((class color) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2990 (background dark)) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2991 (:foreground "pink" :family "helv" |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2992 :height ,(let ((height (face-attribute 'default :height))) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2993 (if (numberp height) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2994 (floor height 0.9) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2995 height)) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2996 :bold t)) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2997 (((class color) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2998 (background light)) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
2999 (:foreground "red" :bold t |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3000 :height ,(let ((height (face-attribute 'default :height))) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3001 (if (numberp height) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3002 (floor height 0.9) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3003 height)))) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3004 (t (:bold t))) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3005 "Face used for group tags." |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3006 :group 'custom-faces) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3007 |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3008 (defface custom-group-tag-face |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3009 `((((class color) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3010 (background dark)) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3011 (:foreground "light blue" :bold t |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3012 :height ,(let ((height (face-attribute 'default :height))) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3013 (if (numberp height) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3014 (floor height 0.9) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3015 height)))) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3016 (((class color) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3017 (background light)) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3018 (:foreground "blue" :bold t |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3019 :height ,(let ((height (face-attribute 'default :height))) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3020 (if (numberp height) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3021 (floor height 0.9) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3022 height)))) |
|
b243caac6505
(custom-variable-tag-face): Handle case that
Gerd Moellmann <gerd@gnu.org>
parents:
28130
diff
changeset
|
3023 (t (:bold t))) |
| 17334 | 3024 "Face used for low level group tags." |
| 17415 | 3025 :group 'custom-faces) |
| 17334 | 3026 |
| 3027 (define-widget 'custom-group 'custom | |
| 3028 "Customize group." | |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3029 :format "%v" |
| 17334 | 3030 :sample-face-get 'custom-group-sample-face-get |
| 3031 :documentation-property 'group-documentation | |
| 3032 :help-echo "Set or reset all members of this group." | |
| 3033 :value-create 'custom-group-value-create | |
| 3034 :action 'custom-group-action | |
| 18089 | 3035 :custom-category 'group |
| 17334 | 3036 :custom-set 'custom-group-set |
| 3037 :custom-save 'custom-group-save | |
| 3038 :custom-reset-current 'custom-group-reset-current | |
| 3039 :custom-reset-saved 'custom-group-reset-saved | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
3040 :custom-reset-standard 'custom-group-reset-standard |
| 17334 | 3041 :custom-menu 'custom-group-menu-create) |
| 3042 | |
| 3043 (defun custom-group-sample-face-get (widget) | |
| 3044 ;; Use :sample-face. | |
| 3045 (or (nth (1- (widget-get widget :custom-level)) custom-group-tag-faces) | |
| 3046 'custom-group-tag-face)) | |
| 3047 | |
|
18430
a8ae9c653696
(custom-group-visibility): Widget type
Richard M. Stallman <rms@gnu.org>
parents:
18373
diff
changeset
|
3048 (define-widget 'custom-group-visibility 'visibility |
|
a8ae9c653696
(custom-group-visibility): Widget type
Richard M. Stallman <rms@gnu.org>
parents:
18373
diff
changeset
|
3049 "An indicator and manipulator for hidden group contents." |
|
a8ae9c653696
(custom-group-visibility): Widget type
Richard M. Stallman <rms@gnu.org>
parents:
18373
diff
changeset
|
3050 :create 'custom-group-visibility-create) |
|
a8ae9c653696
(custom-group-visibility): Widget type
Richard M. Stallman <rms@gnu.org>
parents:
18373
diff
changeset
|
3051 |
|
a8ae9c653696
(custom-group-visibility): Widget type
Richard M. Stallman <rms@gnu.org>
parents:
18373
diff
changeset
|
3052 (defun custom-group-visibility-create (widget) |
|
a8ae9c653696
(custom-group-visibility): Widget type
Richard M. Stallman <rms@gnu.org>
parents:
18373
diff
changeset
|
3053 (let ((visible (widget-value widget))) |
|
a8ae9c653696
(custom-group-visibility): Widget type
Richard M. Stallman <rms@gnu.org>
parents:
18373
diff
changeset
|
3054 (if visible |
|
a8ae9c653696
(custom-group-visibility): Widget type
Richard M. Stallman <rms@gnu.org>
parents:
18373
diff
changeset
|
3055 (insert "--------"))) |
|
a8ae9c653696
(custom-group-visibility): Widget type
Richard M. Stallman <rms@gnu.org>
parents:
18373
diff
changeset
|
3056 (widget-default-create widget)) |
|
a8ae9c653696
(custom-group-visibility): Widget type
Richard M. Stallman <rms@gnu.org>
parents:
18373
diff
changeset
|
3057 |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3058 (defun custom-group-members (symbol groups-only) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3059 "Return SYMBOL's custom group members. |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3060 If GROUPS-ONLY non-nil, return only those members that are groups." |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3061 (if (not groups-only) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3062 (get symbol 'custom-group) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3063 (let (members) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3064 (dolist (entry (get symbol 'custom-group)) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3065 (when (eq (nth 1 entry) 'custom-group) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3066 (push entry members))) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3067 (nreverse members)))) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3068 |
| 17334 | 3069 (defun custom-group-value-create (widget) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3070 "Insert a customize group for WIDGET in the current buffer." |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3071 (let* ((state (widget-get widget :custom-state)) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3072 (level (widget-get widget :custom-level)) |
|
19040
c0dc58ad2d47
Synched with 1.9954.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19022
diff
changeset
|
3073 ;; (indent (widget-get widget :indent)) |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3074 (prefix (widget-get widget :custom-prefix)) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3075 (buttons (widget-get widget :buttons)) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3076 (tag (widget-get widget :tag)) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3077 (symbol (widget-value widget)) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3078 (members (custom-group-members symbol |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3079 (and (eq custom-buffer-style 'tree) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3080 custom-browse-only-groups)))) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3081 (cond ((and (eq custom-buffer-style 'tree) |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
3082 (eq state 'hidden) |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3083 (or members (custom-unloaded-widget-p widget))) |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
3084 (custom-browse-insert-prefix prefix) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3085 (push (widget-create-child-and-convert |
| 25685 | 3086 widget 'custom-browse-visibility |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3087 ;; :tag-glyph "plus" |
|
18856
03eeb83520d8
(custom-group-value-create) <tree>: Don't distinguish
Richard M. Stallman <rms@gnu.org>
parents:
18812
diff
changeset
|
3088 :tag "+") |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3089 buttons) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3090 (insert "-- ") |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3091 ;; (widget-glyph-insert nil "-- " "horizontal") |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3092 (push (widget-create-child-and-convert |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
3093 widget 'custom-browse-group-tag) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3094 buttons) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3095 (insert " " tag "\n") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3096 (widget-put widget :buttons buttons)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3097 ((and (eq custom-buffer-style 'tree) |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3098 (zerop (length members))) |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
3099 (custom-browse-insert-prefix prefix) |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3100 (insert "[ ]-- ") |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3101 ;; (widget-glyph-insert nil "[ ]" "empty") |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3102 ;; (widget-glyph-insert nil "-- " "horizontal") |
| 25685 | 3103 (push (widget-create-child-and-convert |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
3104 widget 'custom-browse-group-tag) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3105 buttons) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3106 (insert " " tag "\n") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3107 (widget-put widget :buttons buttons)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3108 ((eq custom-buffer-style 'tree) |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
3109 (custom-browse-insert-prefix prefix) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3110 (custom-load-widget widget) |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3111 (if (zerop (length members)) |
| 25685 | 3112 (progn |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
3113 (custom-browse-insert-prefix prefix) |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3114 (insert "[ ]-- ") |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3115 ;; (widget-glyph-insert nil "[ ]" "empty") |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3116 ;; (widget-glyph-insert nil "-- " "horizontal") |
| 25685 | 3117 (push (widget-create-child-and-convert |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
3118 widget 'custom-browse-group-tag) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3119 buttons) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3120 (insert " " tag "\n") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3121 (widget-put widget :buttons buttons)) |
| 25685 | 3122 (push (widget-create-child-and-convert |
| 3123 widget 'custom-browse-visibility | |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3124 ;; :tag-glyph "minus" |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3125 :tag "-") |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3126 buttons) |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3127 (insert "-\\ ") |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3128 ;; (widget-glyph-insert nil "-\\ " "top") |
| 25685 | 3129 (push (widget-create-child-and-convert |
|
18562
e22e2a4e683a
Synched with 1.9942.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18462
diff
changeset
|
3130 widget 'custom-browse-group-tag) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3131 buttons) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3132 (insert " " tag "\n") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3133 (widget-put widget :buttons buttons) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3134 (message "Creating group...") |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3135 (let* ((members (custom-sort-items members |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3136 custom-browse-sort-alphabetically |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3137 custom-browse-order-groups)) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3138 (prefixes (widget-get widget :custom-prefixes)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3139 (custom-prefix-list (custom-prefix-add symbol prefixes)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3140 (extra-prefix (if (widget-get widget :custom-last) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3141 " " |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3142 " | ")) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3143 (prefix (concat prefix extra-prefix)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3144 children entry) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3145 (while members |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3146 (setq entry (car members) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3147 members (cdr members)) |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3148 (push (widget-create-child-and-convert |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3149 widget (nth 1 entry) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3150 :group widget |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3151 :tag (custom-unlispify-tag-name (nth 0 entry)) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3152 :custom-prefixes custom-prefix-list |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3153 :custom-level (1+ level) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3154 :custom-last (null members) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3155 :value (nth 0 entry) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3156 :custom-prefix prefix) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3157 children)) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3158 (widget-put widget :children (reverse children))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3159 (message "Creating group...done"))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3160 ;; Nested style. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3161 ((eq state 'hidden) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3162 ;; Create level indicator. |
|
18367
f4682a047be1
(custom-magic-value-create):
Richard M. Stallman <rms@gnu.org>
parents:
18364
diff
changeset
|
3163 (unless (eq custom-buffer-style 'links) |
|
f4682a047be1
(custom-magic-value-create):
Richard M. Stallman <rms@gnu.org>
parents:
18364
diff
changeset
|
3164 (insert-char ?\ (* custom-buffer-indent (1- level))) |
|
f4682a047be1
(custom-magic-value-create):
Richard M. Stallman <rms@gnu.org>
parents:
18364
diff
changeset
|
3165 (insert "-- ")) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3166 ;; Create tag. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3167 (let ((begin (point))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3168 (insert tag) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3169 (widget-specify-sample widget begin (point))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3170 (insert " group: ") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3171 ;; Create link/visibility indicator. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3172 (if (eq custom-buffer-style 'links) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3173 (push (widget-create-child-and-convert |
| 25685 | 3174 widget 'custom-group-link |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3175 :tag "Go to Group" |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3176 symbol) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3177 buttons) |
| 25685 | 3178 (push (widget-create-child-and-convert |
|
20100
0db4553d47cc
(custom-group-value-create): Use
Karl Heuer <kwzh@gnu.org>
parents:
19886
diff
changeset
|
3179 widget 'custom-group-visibility |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3180 :help-echo "Show members of this group." |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3181 :action 'custom-toggle-parent |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3182 (not (eq state 'hidden))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3183 buttons)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3184 (insert " \n") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3185 ;; Create magic button. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3186 (let ((magic (widget-create-child-and-convert |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3187 widget 'custom-magic nil))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3188 (widget-put widget :custom-magic magic) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3189 (push magic buttons)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3190 ;; Update buttons. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3191 (widget-put widget :buttons buttons) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3192 ;; Insert documentation. |
|
18367
f4682a047be1
(custom-magic-value-create):
Richard M. Stallman <rms@gnu.org>
parents:
18364
diff
changeset
|
3193 (if (and (eq custom-buffer-style 'links) (> level 1)) |
|
f4682a047be1
(custom-magic-value-create):
Richard M. Stallman <rms@gnu.org>
parents:
18364
diff
changeset
|
3194 (widget-put widget :documentation-indent 0)) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3195 (widget-default-format-handler widget ?h)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3196 ;; Nested style. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3197 (t ;Visible. |
|
18370
74558272517b
(custom-group-value-create): Use group-visibility widget.
Richard M. Stallman <rms@gnu.org>
parents:
18368
diff
changeset
|
3198 ;; Add parent groups references above the group. |
|
74558272517b
(custom-group-value-create): Use group-visibility widget.
Richard M. Stallman <rms@gnu.org>
parents:
18368
diff
changeset
|
3199 (if t ;;; This should test that the buffer |
|
74558272517b
(custom-group-value-create): Use group-visibility widget.
Richard M. Stallman <rms@gnu.org>
parents:
18368
diff
changeset
|
3200 ;;; was made to display a group. |
|
74558272517b
(custom-group-value-create): Use group-visibility widget.
Richard M. Stallman <rms@gnu.org>
parents:
18368
diff
changeset
|
3201 (when (eq level 1) |
|
18371
a32f9b2c2e0c
(custom-add-parent-links): New arg INITIAL-STRING.
Richard M. Stallman <rms@gnu.org>
parents:
18370
diff
changeset
|
3202 (if (custom-add-parent-links widget |
|
a32f9b2c2e0c
(custom-add-parent-links): New arg INITIAL-STRING.
Richard M. Stallman <rms@gnu.org>
parents:
18370
diff
changeset
|
3203 "Go to parent group:") |
|
18370
74558272517b
(custom-group-value-create): Use group-visibility widget.
Richard M. Stallman <rms@gnu.org>
parents:
18368
diff
changeset
|
3204 (insert "\n")))) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3205 ;; Create level indicator. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3206 (insert-char ?\ (* custom-buffer-indent (1- level))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3207 (insert "/- ") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3208 ;; Create tag. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3209 (let ((start (point))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3210 (insert tag) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3211 (widget-specify-sample widget start (point))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3212 (insert " group: ") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3213 ;; Create visibility indicator. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3214 (unless (eq custom-buffer-style 'links) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3215 (insert "--------") |
| 25685 | 3216 (push (widget-create-child-and-convert |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3217 widget 'visibility |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3218 :help-echo "Hide members of this group." |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3219 :action 'custom-toggle-parent |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3220 (not (eq state 'hidden))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3221 buttons) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3222 (insert " ")) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3223 ;; Create more dashes. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3224 ;; Use 76 instead of 75 to compensate for the temporary "<" |
| 25685 | 3225 ;; added by `widget-insert'. |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3226 (insert-char ?- (- 76 (current-column) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3227 (* custom-buffer-indent level))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3228 (insert "\\\n") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3229 ;; Create magic button. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3230 (let ((magic (widget-create-child-and-convert |
| 25685 | 3231 widget 'custom-magic |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3232 :indent 0 |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3233 nil))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3234 (widget-put widget :custom-magic magic) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3235 (push magic buttons)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3236 ;; Update buttons. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3237 (widget-put widget :buttons buttons) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3238 ;; Insert documentation. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3239 (widget-default-format-handler widget ?h) |
|
18370
74558272517b
(custom-group-value-create): Use group-visibility widget.
Richard M. Stallman <rms@gnu.org>
parents:
18368
diff
changeset
|
3240 ;; Parent groups. |
|
74558272517b
(custom-group-value-create): Use group-visibility widget.
Richard M. Stallman <rms@gnu.org>
parents:
18368
diff
changeset
|
3241 (if nil ;;; This should test that the buffer |
|
74558272517b
(custom-group-value-create): Use group-visibility widget.
Richard M. Stallman <rms@gnu.org>
parents:
18368
diff
changeset
|
3242 ;;; was not made to display a group. |
|
74558272517b
(custom-group-value-create): Use group-visibility widget.
Richard M. Stallman <rms@gnu.org>
parents:
18368
diff
changeset
|
3243 (when (eq level 1) |
|
74558272517b
(custom-group-value-create): Use group-visibility widget.
Richard M. Stallman <rms@gnu.org>
parents:
18368
diff
changeset
|
3244 (insert-char ?\ custom-buffer-indent) |
|
74558272517b
(custom-group-value-create): Use group-visibility widget.
Richard M. Stallman <rms@gnu.org>
parents:
18368
diff
changeset
|
3245 (custom-add-parent-links widget))) |
| 25685 | 3246 (custom-add-see-also widget |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3247 (make-string (* custom-buffer-indent level) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3248 ?\ )) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3249 ;; Members. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3250 (message "Creating group...") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3251 (custom-load-widget widget) |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3252 (let* ((members (custom-sort-items members |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3253 custom-buffer-sort-alphabetically |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3254 custom-buffer-order-groups)) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3255 (prefixes (widget-get widget :custom-prefixes)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3256 (custom-prefix-list (custom-prefix-add symbol prefixes)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3257 (length (length members)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3258 (count 0) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3259 (children (mapcar (lambda (entry) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3260 (widget-insert "\n") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3261 (message "\ |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3262 Creating group members... %2d%%" |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3263 (/ (* 100.0 count) length)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3264 (setq count (1+ count)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3265 (prog1 |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3266 (widget-create-child-and-convert |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3267 widget (nth 1 entry) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3268 :group widget |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3269 :tag (custom-unlispify-tag-name |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3270 (nth 0 entry)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3271 :custom-prefixes custom-prefix-list |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3272 :custom-level (1+ level) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3273 :value (nth 0 entry)) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3274 (unless (eq (preceding-char) ?\n) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3275 (widget-insert "\n")))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3276 members))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3277 (message "Creating group magic...") |
|
28700
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
3278 (mapc 'custom-magic-reset children) |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3279 (message "Creating group state...") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3280 (widget-put widget :children children) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3281 (custom-group-state-update widget) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3282 (message "Creating group... done")) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3283 ;; End line |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3284 (insert "\n") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3285 (insert-char ?\ (* custom-buffer-indent (1- level))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3286 (insert "\\- " (widget-get widget :tag) " group end ") |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3287 (insert-char ?- (- 75 (current-column) (* custom-buffer-indent level))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3288 (insert "/\n"))))) |
| 17334 | 3289 |
| 25685 | 3290 (defvar custom-group-menu |
|
18571
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
3291 '(("Set for Current Session" custom-group-set |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3292 (lambda (widget) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3293 (eq (widget-get widget :custom-state) 'modified))) |
|
18571
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
3294 ("Save for Future Sessions" custom-group-save |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3295 (lambda (widget) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3296 (memq (widget-get widget :custom-state) '(modified set)))) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3297 ("Reset to Current" custom-group-reset-current |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3298 (lambda (widget) |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
3299 (memq (widget-get widget :custom-state) '(modified)))) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3300 ("Reset to Saved" custom-group-reset-saved |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3301 (lambda (widget) |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
3302 (memq (widget-get widget :custom-state) '(modified set)))) |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
3303 ("Reset to standard setting" custom-group-reset-standard |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3304 (lambda (widget) |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
3305 (memq (widget-get widget :custom-state) '(modified set saved))))) |
| 17334 | 3306 "Alist of actions for the `custom-group' widget. |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3307 Each entry has the form (NAME ACTION FILTER) where NAME is the name of |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3308 the menu entry, ACTION is the function to call on the widget when the |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3309 menu is selected, and FILTER is a predicate which takes a `custom-group' |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3310 widget as an argument, and returns non-nil if ACTION is valid on that |
| 25685 | 3311 widget. If FILTER is nil, ACTION is always valid.") |
| 17334 | 3312 |
| 3313 (defun custom-group-action (widget &optional event) | |
| 3314 "Show the menu for `custom-group' WIDGET. | |
| 3315 Optional EVENT is the location for the menu." | |
| 3316 (if (eq (widget-get widget :custom-state) 'hidden) | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3317 (custom-toggle-hide widget) |
| 17334 | 3318 (let* ((completion-ignore-case t) |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
3319 (answer (widget-choose (concat "Operation on " |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
3320 (custom-unlispify-tag-name |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
3321 (widget-get widget :value))) |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3322 (custom-menu-filter custom-group-menu |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3323 widget) |
| 17334 | 3324 event))) |
| 3325 (if answer | |
| 3326 (funcall answer widget))))) | |
| 3327 | |
| 3328 (defun custom-group-set (widget) | |
| 3329 "Set changes in all modified group members." | |
| 3330 (let ((children (widget-get widget :children))) | |
|
28700
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
3331 (mapc (lambda (child) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
3332 (when (eq (widget-get child :custom-state) 'modified) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
3333 (widget-apply child :custom-set))) |
| 17334 | 3334 children ))) |
| 3335 | |
| 3336 (defun custom-group-save (widget) | |
| 3337 "Save all modified group members." | |
| 3338 (let ((children (widget-get widget :children))) | |
|
28700
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
3339 (mapc (lambda (child) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
3340 (when (memq (widget-get child :custom-state) '(modified set)) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
3341 (widget-apply child :custom-save))) |
| 17334 | 3342 children ))) |
| 3343 | |
| 3344 (defun custom-group-reset-current (widget) | |
| 3345 "Reset all modified group members." | |
| 3346 (let ((children (widget-get widget :children))) | |
|
28700
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
3347 (mapc (lambda (child) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
3348 (when (eq (widget-get child :custom-state) 'modified) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
3349 (widget-apply child :custom-reset-current))) |
| 17334 | 3350 children ))) |
| 3351 | |
| 3352 (defun custom-group-reset-saved (widget) | |
| 3353 "Reset all modified or set group members." | |
| 3354 (let ((children (widget-get widget :children))) | |
|
28700
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
3355 (mapc (lambda (child) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
3356 (when (memq (widget-get child :custom-state) '(modified set)) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
3357 (widget-apply child :custom-reset-saved))) |
| 17334 | 3358 children ))) |
| 3359 | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
3360 (defun custom-group-reset-standard (widget) |
| 17334 | 3361 "Reset all modified, set, or saved group members." |
| 3362 (let ((children (widget-get widget :children))) | |
|
28700
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
3363 (mapc (lambda (child) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
3364 (when (memq (widget-get child :custom-state) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
3365 '(modified set saved)) |
|
a57bafeec17c
(Custom-set, Custom-save, Custom-reset-current)
Dave Love <fx@gnu.org>
parents:
28612
diff
changeset
|
3366 (widget-apply child :custom-reset-standard))) |
| 17334 | 3367 children ))) |
| 3368 | |
| 3369 (defun custom-group-state-update (widget) | |
| 3370 "Update magic." | |
| 3371 (unless (eq (widget-get widget :custom-state) 'hidden) | |
| 3372 (let* ((children (widget-get widget :children)) | |
| 3373 (states (mapcar (lambda (child) | |
| 3374 (widget-get child :custom-state)) | |
| 3375 children)) | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
3376 (magics custom-magic-alist) |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
3377 (found 'standard)) |
| 17334 | 3378 (while magics |
| 3379 (let ((magic (car (car magics)))) | |
| 3380 (if (and (not (eq magic 'hidden)) | |
| 3381 (memq magic states)) | |
| 3382 (setq found magic | |
| 3383 magics nil) | |
| 3384 (setq magics (cdr magics))))) | |
| 3385 (widget-put widget :custom-state found))) | |
| 3386 (custom-magic-reset widget)) | |
| 3387 | |
| 3388 ;;; The `custom-save-all' Function. | |
|
18336
325190603227
Synched with 1.9924.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18320
diff
changeset
|
3389 ;;;###autoload |
|
19822
b5c12a2d1c26
*** empty log message ***
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19684
diff
changeset
|
3390 (defcustom custom-file nil |
| 17334 | 3391 "File used for storing customization information. |
|
19822
b5c12a2d1c26
*** empty log message ***
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19684
diff
changeset
|
3392 The default is nil, which means to use your init file |
|
b5c12a2d1c26
*** empty log message ***
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19684
diff
changeset
|
3393 as specified by `user-init-file'. If you specify some other file, |
|
26803
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3394 you need to explicitly load that file for the settings to take effect. |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3395 |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3396 When you change this variable, look in the previous custom file |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3397 \(usually your init file) for the forms `(custom-set-variables ...)' |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3398 and `(custom-set-faces ...)', and copy them (whichever ones you find) |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3399 to the new custom file. This will preserve your existing customizations." |
|
19822
b5c12a2d1c26
*** empty log message ***
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
19684
diff
changeset
|
3400 :type '(choice (const :tag "Your Emacs init file" nil) file) |
| 17334 | 3401 :group 'customize) |
| 3402 | |
| 20974 | 3403 (defun custom-file () |
| 3404 "Return the file name for saving customizations." | |
| 3405 (setq custom-file | |
| 3406 (or custom-file | |
| 3407 user-init-file | |
| 3408 (read-file-name "File for customizations: " | |
| 3409 "~/" nil nil ".emacs")))) | |
| 3410 | |
| 17334 | 3411 (defun custom-save-delete (symbol) |
|
26803
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3412 "Visit `custom-file' and delete all calls to SYMBOL from it. |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3413 Leave point at the old location of the first such call, |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3414 or (if there were none) at the end of the buffer." |
|
20398
47f326ffb7ba
(custom-save-delete, custom-save-all):
Karl Heuer <kwzh@gnu.org>
parents:
20397
diff
changeset
|
3415 (let ((default-major-mode)) |
| 20974 | 3416 (set-buffer (find-file-noselect (custom-file)))) |
| 17334 | 3417 (goto-char (point-min)) |
|
25058
af119d40c92d
(custom-save-delete): Avoid error for empty .emacs.
Karl Heuer <kwzh@gnu.org>
parents:
24509
diff
changeset
|
3418 ;; Skip all whitespace and comments. |
|
af119d40c92d
(custom-save-delete): Avoid error for empty .emacs.
Karl Heuer <kwzh@gnu.org>
parents:
24509
diff
changeset
|
3419 (while (forward-comment 1)) |
|
af119d40c92d
(custom-save-delete): Avoid error for empty .emacs.
Karl Heuer <kwzh@gnu.org>
parents:
24509
diff
changeset
|
3420 (or (eobp) |
|
af119d40c92d
(custom-save-delete): Avoid error for empty .emacs.
Karl Heuer <kwzh@gnu.org>
parents:
24509
diff
changeset
|
3421 (save-excursion (forward-sexp (buffer-size)))) ; Test for scan errors. |
|
26803
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3422 (let (first) |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3423 (catch 'found |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3424 (while t ;; We exit this loop only via throw. |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3425 ;; Skip all whitespace and comments. |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3426 (while (forward-comment 1)) |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3427 (let ((start (point)) |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3428 (sexp (condition-case nil |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3429 (read (current-buffer)) |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3430 (end-of-file (throw 'found nil))))) |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3431 (when (and (listp sexp) |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3432 (eq (car sexp) symbol)) |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3433 (delete-region start (point)) |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3434 (unless first |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3435 (setq first (point))))))) |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3436 (if first |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3437 (goto-char first) |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3438 (goto-char (point-max))))) |
| 17334 | 3439 |
| 3440 (defun custom-save-variables () | |
| 3441 "Save all customized variables in `custom-file'." | |
| 3442 (save-excursion | |
| 3443 (custom-save-delete 'custom-set-variables) | |
|
25059
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3444 (let ((standard-output (current-buffer)) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3445 (saved-list (make-list 1 0)) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3446 sort-fold-case) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3447 ;; First create a sorted list of saved variables. |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3448 (mapatoms |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3449 (lambda (symbol) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3450 (if (get symbol 'saved-value) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3451 (nconc saved-list (list symbol))))) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3452 (setq saved-list (sort (cdr saved-list) 'string<)) |
| 17334 | 3453 (unless (bolp) |
| 3454 (princ "\n")) | |
|
26653
ea8ae3c8fad5
(custom-save-variables, custom-save-faces): Write a
Dave Love <fx@gnu.org>
parents:
26625
diff
changeset
|
3455 (princ "(custom-set-variables |
|
ea8ae3c8fad5
(custom-save-variables, custom-save-faces): Write a
Dave Love <fx@gnu.org>
parents:
26625
diff
changeset
|
3456 ;; custom-set-variables was added by Custom -- don't edit or cut/paste it! |
|
26803
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3457 ;; Your init file must only contain one such instance.\n") |
|
25059
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3458 (mapcar |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3459 (lambda (symbol) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3460 (let ((value (get symbol 'saved-value)) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3461 (requests (get symbol 'custom-requests)) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3462 (now (not (or (get symbol 'standard-value) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3463 (and (not (boundp symbol)) |
| 25685 | 3464 (not (get symbol 'force-value)))))) |
| 3465 (comment (get symbol 'saved-variable-comment)) | |
| 3466 sep) | |
| 3467 (when (or value comment) | |
|
26803
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3468 (unless (bolp) |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3469 (princ "\n")) |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3470 (princ " '(") |
| 25685 | 3471 (prin1 symbol) |
| 3472 (princ " ") | |
| 3473 (prin1 (car value)) | |
| 3474 (cond ((or now requests comment) | |
| 3475 (princ " ") | |
| 3476 (if now | |
| 3477 (princ "t") | |
| 3478 (princ "nil")) | |
| 3479 (cond ((or requests comment) | |
| 3480 (princ " ") | |
| 3481 (if requests | |
| 3482 (prin1 requests) | |
| 3483 (princ "nil")) | |
| 3484 (cond (comment | |
| 3485 (princ " ") | |
| 3486 (prin1 comment) | |
| 3487 (princ ")")) | |
| 3488 (t | |
| 3489 (princ ")")))) | |
| 3490 (t | |
| 3491 (princ ")")))) | |
| 3492 (t | |
| 3493 (princ ")")))))) | |
|
25059
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3494 saved-list) |
|
26803
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3495 (if (bolp) |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3496 (princ " ")) |
| 17334 | 3497 (princ ")") |
| 3498 (unless (looking-at "\n") | |
| 3499 (princ "\n"))))) | |
| 3500 | |
| 3501 (defun custom-save-faces () | |
| 3502 "Save all customized faces in `custom-file'." | |
| 3503 (save-excursion | |
| 3504 (custom-save-delete 'custom-set-faces) | |
|
25059
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3505 (let ((standard-output (current-buffer)) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3506 (saved-list (make-list 1 0)) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3507 sort-fold-case) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3508 ;; First create a sorted list of saved faces. |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3509 (mapatoms |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3510 (lambda (symbol) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3511 (if (get symbol 'saved-face) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3512 (nconc saved-list (list symbol))))) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3513 (setq saved-list (sort (cdr saved-list) 'string<)) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3514 ;; The default face must be first, since it affects the others. |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3515 (if (memq 'default saved-list) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3516 (setq saved-list (cons 'default (delq 'default saved-list)))) |
| 17334 | 3517 (unless (bolp) |
| 3518 (princ "\n")) | |
|
26653
ea8ae3c8fad5
(custom-save-variables, custom-save-faces): Write a
Dave Love <fx@gnu.org>
parents:
26625
diff
changeset
|
3519 (princ "(custom-set-faces |
|
ea8ae3c8fad5
(custom-save-variables, custom-save-faces): Write a
Dave Love <fx@gnu.org>
parents:
26625
diff
changeset
|
3520 ;; custom-set-faces was added by Custom -- don't edit or cut/paste it! |
|
26803
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3521 ;; Your init file must only contain one such instance.\n") |
|
25059
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3522 (mapcar |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3523 (lambda (symbol) |
| 25685 | 3524 (let ((value (get symbol 'saved-face)) |
| 3525 (now (not (or (get 'default 'face-defface-spec) | |
| 3526 (and (not (custom-facep 'default)) | |
| 3527 (not (get 'default 'force-face)))))) | |
| 3528 (comment (get 'default 'saved-face-comment))) | |
|
25059
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3529 (unless (eq symbol 'default)) |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3530 ;; Don't print default face here. |
|
26803
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3531 (unless (bolp) |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3532 (princ "\n")) |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3533 (princ " '(") |
| 25685 | 3534 (prin1 symbol) |
|
25059
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3535 (princ " ") |
|
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3536 (prin1 value) |
| 25685 | 3537 (cond ((or now comment) |
| 3538 (princ " ") | |
| 3539 (if now | |
| 3540 (princ "t") | |
| 3541 (princ "nil")) | |
| 3542 (cond (comment | |
| 3543 (princ " ") | |
| 3544 (prin1 comment) | |
| 3545 (princ ")")) | |
| 3546 (t | |
| 3547 (princ ")")))) | |
| 3548 (t | |
| 3549 (princ ")"))))) | |
|
25059
d6081fb56cda
(custom-save-variables, custom-save-faces): Sort
Markus Rost <rost@math.uni-bielefeld.de>
parents:
25058
diff
changeset
|
3550 saved-list) |
|
26803
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3551 (if (bolp) |
|
f7c68655bd5d
(custom-save-delete): Delete all occurrences,
Richard M. Stallman <rms@gnu.org>
parents:
26653
diff
changeset
|
3552 (princ " ")) |
| 17334 | 3553 (princ ")") |
| 3554 (unless (looking-at "\n") | |
| 3555 (princ "\n"))))) | |
| 3556 | |
| 3557 ;;;###autoload | |
|
18436
2163f03bb88f
(customize-save-customized): Renamed from custom-save-customized.
Richard M. Stallman <rms@gnu.org>
parents:
18435
diff
changeset
|
3558 (defun customize-save-customized () |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3559 "Save all user options which have been set in this session." |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3560 (interactive) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3561 (mapatoms (lambda (symbol) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3562 (let ((face (get symbol 'customized-face)) |
| 25685 | 3563 (value (get symbol 'customized-value)) |
| 3564 (face-comment (get symbol 'customized-face-comment)) | |
| 3565 (variable-comment | |
| 3566 (get symbol 'customized-variable-comment))) | |
| 3567 (when face | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3568 (put symbol 'saved-face face) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3569 (put symbol 'customized-face nil)) |
| 25685 | 3570 (when value |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3571 (put symbol 'saved-value value) |
| 25685 | 3572 (put symbol 'customized-value nil)) |
| 3573 (when variable-comment | |
| 3574 (put symbol 'saved-variable-comment variable-comment) | |
| 3575 (put symbol 'customized-variable-comment nil)) | |
| 3576 (when face-comment | |
| 3577 (put symbol 'saved-face-comment face-comment) | |
| 3578 (put symbol 'customized-face-comment nil))))) | |
|
17550
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3579 ;; We really should update all custom buffers here. |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3580 (custom-save-all)) |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3581 |
|
d6545cfb6c5a
Synched with custom 1.90.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17534
diff
changeset
|
3582 ;;;###autoload |
| 17334 | 3583 (defun custom-save-all () |
| 3584 "Save all customizations in `custom-file'." | |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3585 (let ((inhibit-read-only t)) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3586 (custom-save-variables) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3587 (custom-save-faces) |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3588 (save-excursion |
|
20398
47f326ffb7ba
(custom-save-delete, custom-save-all):
Karl Heuer <kwzh@gnu.org>
parents:
20397
diff
changeset
|
3589 (let ((default-major-mode nil)) |
| 20974 | 3590 (set-buffer (find-file-noselect (custom-file)))) |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3591 (save-buffer)))) |
| 17334 | 3592 |
| 3593 ;;; The Customize Menu. | |
| 3594 | |
| 17415 | 3595 ;;; Menu support |
| 3596 | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
3597 (defcustom custom-menu-nesting 2 |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
3598 "Maximum nesting in custom menus." |
|
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
3599 :type 'integer |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
3600 :group 'custom-menu) |
| 17334 | 3601 |
| 3602 (defun custom-face-menu-create (widget symbol) | |
| 3603 "Ignoring WIDGET, create a menu entry for customization face SYMBOL." | |
| 3604 (vector (custom-unlispify-menu-entry symbol) | |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
3605 `(customize-face ',symbol) |
| 17334 | 3606 t)) |
| 3607 | |
| 3608 (defun custom-variable-menu-create (widget symbol) | |
| 3609 "Ignoring WIDGET, create a menu entry for customization variable SYMBOL." | |
| 3610 (let ((type (get symbol 'custom-type))) | |
| 3611 (unless (listp type) | |
| 3612 (setq type (list type))) | |
| 3613 (if (and type (widget-get type :custom-menu)) | |
| 3614 (widget-apply type :custom-menu symbol) | |
| 3615 (vector (custom-unlispify-menu-entry symbol) | |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
3616 `(customize-variable ',symbol) |
| 17334 | 3617 t)))) |
| 3618 | |
| 17415 | 3619 ;; Add checkboxes to boolean variable entries. |
| 17334 | 3620 (widget-put (get 'boolean 'widget-type) |
| 3621 :custom-menu (lambda (widget symbol) | |
| 3622 (vector (custom-unlispify-menu-entry symbol) | |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
3623 `(customize-variable ',symbol) |
| 17334 | 3624 ':style 'toggle |
| 3625 ':selected symbol))) | |
| 3626 | |
|
26451
91e697e38599
(customize-face, customize-face-other-window): Require match from
Dave Love <fx@gnu.org>
parents:
25847
diff
changeset
|
3627 ;; Fixme: sort out use of :filter in Emacs 21. |
| 25685 | 3628 (if nil ; (string-match "XEmacs" emacs-version) |
| 17334 | 3629 ;; XEmacs can create menus dynamically. |
| 3630 (defun custom-group-menu-create (widget symbol) | |
| 3631 "Ignoring WIDGET, create a menu entry for customization group SYMBOL." | |
| 3632 `( ,(custom-unlispify-menu-entry symbol t) | |
| 3633 :filter (lambda (&rest junk) | |
| 3634 (cdr (custom-menu-create ',symbol))))) | |
| 3635 ;; But emacs can't. | |
| 3636 (defun custom-group-menu-create (widget symbol) | |
| 3637 "Ignoring WIDGET, create a menu entry for customization group SYMBOL." | |
| 3638 ;; Limit the nesting. | |
| 3639 (let ((custom-menu-nesting (1- custom-menu-nesting))) | |
| 3640 (custom-menu-create symbol)))) | |
| 3641 | |
| 17415 | 3642 ;;;###autoload |
| 3643 (defun custom-menu-create (symbol) | |
| 17334 | 3644 "Create menu for customization group SYMBOL. |
| 3645 The menu is in a format applicable to `easy-menu-define'." | |
| 17415 | 3646 (let* ((item (vector (custom-unlispify-menu-entry symbol) |
|
17798
f59c9a63514b
Synched with version 1.97.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
17703
diff
changeset
|
3647 `(customize-group ',symbol) |
| 17415 | 3648 t))) |
| 3649 (if (and (or (not (boundp 'custom-menu-nesting)) | |
| 3650 (>= custom-menu-nesting 0)) | |
| 17334 | 3651 (< (length (get symbol 'custom-group)) widget-menu-max-size)) |
| 3652 (let ((custom-prefix-list (custom-prefix-add symbol | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
3653 custom-prefix-list)) |
|
18451
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3654 (members (custom-sort-items (get symbol 'custom-group) |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3655 custom-menu-sort-alphabetically |
|
8eb08560287b
Synched with 1.9936.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18437
diff
changeset
|
3656 custom-menu-order-groups))) |
| 17334 | 3657 (custom-load-symbol symbol) |
| 3658 `(,(custom-unlispify-menu-entry symbol t) | |
| 3659 ,item | |
| 3660 "--" | |
| 3661 ,@(mapcar (lambda (entry) | |
| 3662 (widget-apply (if (listp (nth 1 entry)) | |
| 3663 (nth 1 entry) | |
| 3664 (list (nth 1 entry))) | |
| 3665 :custom-menu (nth 0 entry))) | |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
3666 members))) |
| 17334 | 3667 item))) |
| 3668 | |
| 3669 ;;;###autoload | |
| 17415 | 3670 (defun customize-menu-create (symbol &optional name) |
| 3671 "Return a customize menu for customization group SYMBOL. | |
| 25685 | 3672 If optional NAME is given, use that as the name of the menu. |
| 17415 | 3673 Otherwise the menu will be named `Customize'. |
| 3674 The format is suitable for use with `easy-menu-define'." | |
| 3675 (unless name | |
| 3676 (setq name "Customize")) | |
|
26451
91e697e38599
(customize-face, customize-face-other-window): Require match from
Dave Love <fx@gnu.org>
parents:
25847
diff
changeset
|
3677 ;; Fixme: sort out use of :filter in Emacs 21. |
| 25685 | 3678 (if nil ;(string-match "XEmacs" emacs-version) |
| 17415 | 3679 ;; We can delay it under XEmacs. |
| 3680 `(,name | |
| 3681 :filter (lambda (&rest junk) | |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3682 (cdr (custom-menu-create ',symbol)))) |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3683 ;; But we must create it now under Emacs. |
|
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3684 (cons name (cdr (custom-menu-create symbol))))) |
| 17334 | 3685 |
| 17415 | 3686 ;;; The Custom Mode. |
| 3687 | |
| 3688 (defvar custom-mode-map nil | |
| 3689 "Keymap for `custom-mode'.") | |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3690 |
| 17415 | 3691 (unless custom-mode-map |
| 3692 (setq custom-mode-map (make-sparse-keymap)) | |
| 3693 (set-keymap-parent custom-mode-map widget-keymap) | |
|
18139
ee3c0d09dcd3
Synched with 1.9908.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18131
diff
changeset
|
3694 (suppress-keymap custom-mode-map) |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3695 (define-key custom-mode-map " " 'scroll-up) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3696 (define-key custom-mode-map "\177" 'scroll-down) |
| 25685 | 3697 (define-key custom-mode-map "q" 'Custom-buffer-done) |
|
18460
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
3698 (define-key custom-mode-map "u" 'Custom-goto-parent) |
|
18609
242173dd0e67
(custom-mode-map): Bind n and p.
Richard M. Stallman <rms@gnu.org>
parents:
18606
diff
changeset
|
3699 (define-key custom-mode-map "n" 'widget-forward) |
|
242173dd0e67
(custom-mode-map): Bind n and p.
Richard M. Stallman <rms@gnu.org>
parents:
18606
diff
changeset
|
3700 (define-key custom-mode-map "p" 'widget-backward) |
|
18460
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
3701 (define-key custom-mode-map [mouse-1] 'Custom-move-and-invoke)) |
|
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
3702 |
|
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
3703 (defun Custom-move-and-invoke (event) |
|
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
3704 "Move to where you click, and if it is an active field, invoke it." |
|
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
3705 (interactive "e") |
|
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
3706 (mouse-set-point event) |
|
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
3707 (if (widget-event-point event) |
|
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
3708 (let* ((pos (widget-event-point event)) |
|
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
3709 (button (get-char-property pos 'button))) |
|
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
3710 (if button |
|
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
3711 (widget-button-click event))))) |
| 17415 | 3712 |
| 25685 | 3713 (easy-menu-define Custom-mode-menu |
| 17415 | 3714 custom-mode-map |
| 3715 "Menu used in customization buffers." | |
| 3716 `("Custom" | |
|
18364
01666331d10f
Synched with 1.9930.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18362
diff
changeset
|
3717 ,(customize-menu-create 'customize) |
|
18435
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
3718 ["Set" Custom-set t] |
|
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
3719 ["Save" Custom-save t] |
|
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
3720 ["Reset to Current" Custom-reset-current t] |
|
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
3721 ["Reset to Saved" Custom-reset-saved t] |
|
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
3722 ["Reset to Standard Settings" Custom-reset-standard t] |
|
23357
856a82c440fa
(Custom-mode-menu): Fix info node name.
Karl Heuer <kwzh@gnu.org>
parents:
23223
diff
changeset
|
3723 ["Info" (Info-goto-node "(emacs)Easy Customization") t])) |
| 17415 | 3724 |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3725 (defun Custom-goto-parent () |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3726 "Go to the parent group listed at the top of this buffer. |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3727 If several parents are listed, go to the first of them." |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3728 (interactive) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3729 (save-excursion |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3730 (goto-char (point-min)) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3731 (if (search-forward "\nGo to parent group: " nil t) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3732 (let* ((button (get-char-property (point) 'button)) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3733 (parent (downcase (widget-get button :tag)))) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3734 (customize-group parent))))) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3735 |
| 17415 | 3736 (defcustom custom-mode-hook nil |
| 25685 | 3737 "Hook called when entering Custom mode." |
| 17415 | 3738 :type 'hook |
|
18244
909a0f9169b8
Synched with 1.9914.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18139
diff
changeset
|
3739 :group 'custom-buffer ) |
| 17415 | 3740 |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3741 (defun custom-state-buffer-message (widget) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3742 (if (eq (widget-get (widget-get widget :parent) :custom-state) 'modified) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3743 (message "To install your edits, invoke [State] and choose the Set operation"))) |
|
18430
a8ae9c653696
(custom-group-visibility): Widget type
Richard M. Stallman <rms@gnu.org>
parents:
18373
diff
changeset
|
3744 |
| 17415 | 3745 (defun custom-mode () |
| 3746 "Major mode for editing customization buffers. | |
| 3747 | |
| 3748 The following commands are available: | |
| 3749 | |
| 3750 Move to next button or editable field. \\[widget-forward] | |
| 3751 Move to previous button or editable field. \\[widget-backward] | |
|
19022
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3752 \\<widget-field-keymap>\ |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3753 Complete content of editable text field. \\[widget-complete] |
|
904dcdbb8576
Synched with 1.9951.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18856
diff
changeset
|
3754 \\<custom-mode-map>\ |
|
18460
a2be4f4ac8ed
(Custom-move-and-invoke): New command.
Richard M. Stallman <rms@gnu.org>
parents:
18451
diff
changeset
|
3755 Invoke button under the mouse pointer. \\[Custom-move-and-invoke] |
|
18033
bccd356a3b7c
Synched with version 1.9900.
Per Abrahamsen <abraham@dina.kvl.dk>
parents:
18032
diff
changeset
|
3756 Invoke button under point. \\[widget-button-press] |
|
18435
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
3757 Set all modifications. \\[Custom-set] |
|
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
3758 Make all modifications default. \\[Custom-save] |
|
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
3759 Reset all modified options. \\[Custom-reset-current] |
|
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
3760 Reset all modified or set options. \\[Custom-reset-saved] |
|
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
3761 Reset all options. \\[Custom-reset-standard] |
| 17415 | 3762 |
| 3763 Entry to this mode calls the value of `custom-mode-hook' | |
| 3764 if that value is non-nil." | |
| 3765 (kill-all-local-variables) | |
| 3766 (setq major-mode 'custom-mode | |
| 3767 mode-name "Custom") | |
| 3768 (use-local-map custom-mode-map) | |
|
18435
2f906938425b
(Custom-set): Renamed from custom-set.
Richard M. Stallman <rms@gnu.org>
parents:
18430
diff
changeset
|
3769 (easy-menu-add Custom-mode-menu) |
| 17415 | 3770 (make-local-variable 'custom-options) |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3771 (make-local-variable 'widget-documentation-face) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3772 (setq widget-documentation-face 'custom-documentation-face) |
|
18571
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
3773 (make-local-variable 'widget-button-face) |
|
1beba85e8c62
(custom-buffer-create-internal): New arg DESCRIPTION
Richard M. Stallman <rms@gnu.org>
parents:
18562
diff
changeset
|
3774 (setq widget-button-face 'custom-button-face) |
| 25685 | 3775 (set (make-local-variable 'widget-button-pressed-face) |
| 3776 'custom-button-pressed-face) | |
| 3777 (set (make-local-variable 'widget-mouse-face) | |
| 3778 'custom-button-pressed-face) ; buttons `depress' when moused | |
| 3779 ;; When possible, use relief for buttons, not bracketing. This test | |
| 3780 ;; may not be optimal. | |
| 3781 (when custom-raised-buttons | |
| 3782 (set (make-local-variable 'widget-push-button-prefix) "") | |
| 3783 (set (make-local-variable 'widget-push-button-suffix) "") | |
| 3784 (set (make-local-variable 'widget-link-prefix) "") | |
| 3785 (set (make-local-variable 'widget-link-suffix) "")) | |
|
18437
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3786 (make-local-hook 'widget-edit-functions) |
|
cbaf72286a2e
(custom-documentation-face): New face.
Richard M. Stallman <rms@gnu.org>
parents:
18436
diff
changeset
|
3787 (add-hook 'widget-edit-functions 'custom-state-buffer-message nil t) |
| 17415 | 3788 (run-hooks 'custom-mode-hook)) |
| 17334 | 3789 |
| 28130 | 3790 (add-to-list |
| 3791 'debug-ignored-errors | |
| 3792 "^No user options have changed defaults in recent Emacs versions$") | |
| 3793 | |
| 17334 | 3794 ;;; The End. |
| 3795 | |
| 3796 (provide 'cus-edit) | |
| 3797 | |
| 25685 | 3798 ;;; cus-edit.el ends here |
