diff options
author | Richard M. Stallman <rms@gnu.org> | 1993-08-02 07:23:24 +0000 |
---|---|---|
committer | Richard M. Stallman <rms@gnu.org> | 1993-08-02 07:23:24 +0000 |
commit | 23f87cce43f42f8e623da0fe8abeabd0af76022a (patch) | |
tree | 1bc642616a2f5839a4f4d189b75924f44fee4eac /lisp/emacs-lisp/lucid.el | |
parent | 322959764a2b05f0210adc474fab6876b45cb53f (diff) | |
download | emacs-23f87cce43f42f8e623da0fe8abeabd0af76022a.tar.gz |
(remove-hook): Doc string added.
Change a single function into a list.
Diffstat (limited to 'lisp/emacs-lisp/lucid.el')
-rw-r--r-- | lisp/emacs-lisp/lucid.el | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/lisp/emacs-lisp/lucid.el b/lisp/emacs-lisp/lucid.el index 144aaf35b22..eaa405afd33 100644 --- a/lisp/emacs-lisp/lucid.el +++ b/lisp/emacs-lisp/lucid.el @@ -53,8 +53,16 @@ (setcdr tail new-parent)))) (defun remove-hook (hook-var function) + "Remove a function from a hook, if it is present. +First argument HOOK-VAR (a symbol) is the name of a hook, second + argument FUNCTION is the function to remove (compared with `eq')." (if (boundp 'hook-var) - (set hook-var (delq function (symbol-value hook-var))))) + (let ((old (symbol-value hook-var))) + ;; If the hook value is a single function, turn it into a list. + (if (or (not (listp old)) (eq (car old) 'lambda)) + (set hook-var (list old))) + ;; Now delete FUNCTION. + (set hook-var (delq function (symbol-value hook-var)))))) (defun remprop (symbol prop) (let ((plist (symbol-plist symbol))) |