changeset 45607:98941f178aa2

(choose-completion-string-functions): New special hook. (choose-completion-string1): Renamed from choose-completion-string. (choose-completion-string): Run choose-completion-string-functions until success, and only call choose-completion-string1 if it fails.
author Kim F. Storm <storm@cua.dk>
date Sat, 01 Jun 2002 00:00:29 +0000
parents 58b152d88dbd
children 706ae7fb4033
files lisp/simple.el
diffstat 1 files changed, 12 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- a/lisp/simple.el	Fri May 31 23:59:50 2002 +0000
+++ b/lisp/simple.el	Sat Jun 01 00:00:29 2002 +0000
@@ -3777,6 +3777,13 @@
       (forward-char 1))
     (delete-char len)))
 
+(defvar choose-completion-string-functions nil
+  "List of functions which may override the standard `choose-completion-string'.
+Each function in the list is called in turn with arguments CHOICE BUFFER BASE-SIZE
+like choose-completion-string.  If a function in the list returns non-nil, that
+function is supposed to have inserted the completion in the minibuffer.
+If all functions in the list return nil, use the default completion selection.")
+
 ;; Switch to BUFFER and insert the completion choice CHOICE.
 ;; BASE-SIZE, if non-nil, says how many characters of BUFFER's text
 ;; to keep.  If it is nil, use choose-completion-delete-max-match instead.
@@ -3785,6 +3792,11 @@
 ;; unless it is reading a file name and CHOICE is a directory,
 ;; or completion-no-auto-exit is non-nil.
 (defun choose-completion-string (choice &optional buffer base-size)
+  (unless (run-hook-with-args-until-success 
+	   'choose-completion-string-functions choice buffer base-size)
+    (choose-completion-string1 choice buffer base-size)))
+
+(defun choose-completion-string1 (choice &optional buffer base-size)
   (let ((buffer (or buffer completion-reference-buffer))
 	(mini-p (string-match "\\` \\*Minibuf-[0-9]+\\*\\'" (buffer-name buffer))))
     ;; If BUFFER is a minibuffer, barf unless it's the currently