From: Richard M. Stallman Date: Sun, 28 Apr 2002 03:23:52 +0000 (+0000) Subject: (custom-load-symbol): Moved from cus-edit.el. X-Git-Tag: ttn-vms-21-2-B4~15359 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=8f772dfd7a4e2cc2e0fb0a9dad558b7852f16755;p=emacs.git (custom-load-symbol): Moved from cus-edit.el. (custom-load-recursion): Likewise. --- 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