From af447694e7ceb50ea86e9ea8207e2ae18d1820fa Mon Sep 17 00:00:00 2001 From: "Richard M. Stallman" Date: Fri, 23 Dec 1994 05:05:22 +0000 Subject: [PATCH] (imenu-always-use-completion-buffer-p): A value of `never' now means never display a completion buffer. (imenu--completion-buffer): implement 'never behaviour. --- lisp/imenu.el | 41 +++++++++++++++++++++++------------------ 1 file changed, 23 insertions(+), 18 deletions(-) diff --git a/lisp/imenu.el b/lisp/imenu.el index bd7c1adbe02..aa4dd433dbe 100644 --- a/lisp/imenu.el +++ b/lisp/imenu.el @@ -5,7 +5,7 @@ ;; Author: Ake Stenhoff ;; Lars Lindberg ;; Created: 8 Feb 1994 -;; Version: 1.14 +;; Version: 1.15 ;; Keywords: tools ;; ;; This program is free software; you can redistribute it and/or modify @@ -49,7 +49,7 @@ ;; [greg] - Greg Thompson gregt@porsche.visix.COM ;; [wolfgang] - Wolfgang Bangerth zcg51122@rpool1.rus.uni-stuttgart.de ;; [kai] - Kai Grossjohann grossjoh@linus.informatik.uni-dortmund.de - +;; [david] - David M. Smith dsmith@stats.adelaide.edu.au ;;; Code (eval-when-compile (require 'cl)) @@ -64,7 +64,8 @@ Non-nil means always display the index in a completion buffer. Nil means display the index as a mouse menu when the mouse was -used to invoke `imenu'.") +used to invoke `imenu'. +`never' means never automatically display a listing of any kind.") (defvar imenu-sort-function nil "*The function to use for sorting the index mouse-menu. @@ -653,21 +654,25 @@ Returns t for rescan and otherwise a position number." (cons (imenu--replace-spaces (car item) imenu-space-replacement) (cdr item)))) index-alist))) - (save-window-excursion - ;; Display the completion buffer - (with-output-to-temp-buffer "*Completions*" - (display-completion-list - (all-completions "" prepared-index-alist ))) - (let ((minibuffer-setup-hook - (function (lambda () - (let ((buffer (current-buffer))) - (save-excursion - (set-buffer "*Completions*") - (setq completion-reference-buffer buffer))))))) - ;; Make a completion question - (setq name (completing-read (or prompt "Index item: ") - prepared-index-alist - nil t nil 'imenu--history-list)))) + (if (eq imenu-always-use-completion-buffer-p 'never) + (setq name (completing-read (or prompt "Index item: ") + prepared-index-alist + nil t nil 'imenu--history-list)) + (save-window-excursion + ;; Display the completion buffer + (with-output-to-temp-buffer "*Completions*" + (display-completion-list + (all-completions "" prepared-index-alist ))) + (let ((minibuffer-setup-hook + (function (lambda () + (let ((buffer (current-buffer))) + (save-excursion + (set-buffer "*Completions*") + (setq completion-reference-buffer buffer))))))) + ;; Make a completion question + (setq name (completing-read (or prompt "Index item: ") + prepared-index-alist + nil t nil 'imenu--history-list))))) (cond ((not (stringp name)) nil) ((string= name (car imenu--rescan-item))