diff options
author | Richard M. Stallman <rms@gnu.org> | 2002-04-28 03:23:52 +0000 |
---|---|---|
committer | Richard M. Stallman <rms@gnu.org> | 2002-04-28 03:23:52 +0000 |
commit | 8f772dfd7a4e2cc2e0fb0a9dad558b7852f16755 (patch) | |
tree | 6c856470a55adb37af258bcdc2d31166df4108e6 | |
parent | e8e98f20c2f0a346c5f43905d297ebe7169485f0 (diff) | |
download | emacs-8f772dfd7a4e2cc2e0fb0a9dad558b7852f16755.tar.gz |
(custom-load-symbol): Moved from cus-edit.el.
(custom-load-recursion): Likewise.
-rw-r--r-- | lisp/custom.el | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/lisp/custom.el b/lisp/custom.el index cae8450c968..c12f3bec2e7 100644 --- a/lisp/custom.el +++ b/lisp/custom.el @@ -457,6 +457,47 @@ LOAD should be either a library file name, or a feature name." (unless (member load loads) (put symbol 'custom-loads (cons (purecopy load) loads))))) +;;; Loading files needed to customize a symbol. +;;; This is in custom.el because menu-bar.el needs it for toggle cmds. + +(defvar custom-load-recursion nil + "Hack to avoid recursive dependencies.") + +(defun custom-load-symbol (symbol) + "Load all dependencies for SYMBOL." + (unless custom-load-recursion + (let ((custom-load-recursion t) + (loads (get symbol 'custom-loads)) + load) + (while loads + (setq load (car loads) + loads (cdr loads)) + (cond ((symbolp load) + (condition-case nil + (require load) + (error nil))) + ;; Don't reload a file already loaded. + ((and (boundp 'preloaded-file-list) + (member load preloaded-file-list))) + ((assoc load load-history)) + ;; This was just (assoc (locate-library load) load-history) + ;; but has been optimized not to load locate-library + ;; if not necessary. + ((let (found (regexp (regexp-quote load))) + (dolist (loaded load-history) + (and (string-match regexp (car loaded)) + (eq (locate-library load) (car loaded)) + (setq found t))) + found)) + ;; Without this, we would load cus-edit recursively. + ;; We are still loading it when we call this, + ;; and it is not in load-history yet. + ((equal load "cus-edit")) + (t + (condition-case nil + (load-library load) + (error nil)))))))) + ;;; Initializing. (defvar custom-local-buffer nil |