diff options
| author | John Wiegley <johnw@newartisans.com> | 2004-04-17 22:04:04 +0000 | 
|---|---|---|
| committer | John Wiegley <johnw@newartisans.com> | 2004-04-17 22:04:04 +0000 | 
| commit | c80d953400f64cc8d7c336074aa7581749a54a27 (patch) | |
| tree | f4904463394475cf4d9b87181801a0c78a0d0699 | |
| parent | 554e27417b3e621a40b72cc75f9a3424330bf7e7 (diff) | |
| download | emacs-c80d953400f64cc8d7c336074aa7581749a54a27.tar.gz | |
2004-04-17  John Wiegley  <johnw@newartisans.com>
	* iswitchb.el (iswitchb-max-to-show): Added a new config variable
	which optionally limits the number of names shown in the
	minibuffer.  Off by default.
	(iswitchb-completions): Use `iswitchb-max-to-show'.  This speeds
	up iswitchb for users with a multitude of open buffers, by showing
	only the first and last N/2 buffers in the completion list (which
	is enough for C-s/C-r, and to know that more characters need to be
	typed to refine the completion list).
| -rw-r--r-- | lisp/iswitchb.el | 45 | 
1 files changed, 28 insertions, 17 deletions
| diff --git a/lisp/iswitchb.el b/lisp/iswitchb.el index aab768387d0..0c43c270751 100644 --- a/lisp/iswitchb.el +++ b/lisp/iswitchb.el @@ -298,6 +298,13 @@ example functions that filter buffernames."    :type '(repeat (choice regexp function))    :group 'iswitchb) +(defcustom iswitchb-max-to-show nil +  "*If non-nil, limit the number of names shown in the minibuffer. +This can greatly speed up iswitchb if you have a multitude of +buffers open." +  :type 'integer +  :group 'iswitchb) +  (defcustom iswitchb-cannot-complete-hook 'iswitchb-completion-help    "*Hook run when `iswitchb-complete' can't complete any more.  The most useful values are `iswitchb-completion-help', which pops up a @@ -1185,6 +1192,15 @@ Copied from `icomplete-exhibit' with two changes:  		   contents  		   (not minibuffer-completion-confirm))))))) +(defun iswitchb-output-completion (com) +  (if (= (length com) most-len) +      ;; Most is one exact match, +      ;; note that and leave out +      ;; for later indication: +      (ignore +       (setq most-is-exact t)) +    (substring com most-len))) +  (defun iswitchb-completions (name require-match)    "Return the string that is displayed after the user's text.  Modified from `icomplete-completions'." @@ -1224,28 +1240,23 @@ Modified from `icomplete-completions'."  		     "")  		   (if (not iswitchb-use-fonts) " [Matched]")))  	  (t				;multiple matches +	   (if (and iswitchb-max-to-show +		    (> (length comps) iswitchb-max-to-show)) +	       (setq comps +		     (append +		      (subseq comps 0 (/ iswitchb-max-to-show 2)) +		      (list "...") +		      (subseq comps (- (length comps) +				       (/ iswitchb-max-to-show 2))))))  	   (let* (  		  ;;(most (try-completion name candidates predicate))  		  (most nil)  		  (most-len (length most))  		  most-is-exact -		  (alternatives -		   (apply -		    (function concat) -		    (cdr (apply -			  (function nconc) -			  (mapcar '(lambda (com) -				     (if (= (length com) most-len) -					 ;; Most is one exact match, -					 ;; note that and leave out -					 ;; for later indication: -					 (progn -					   (setq most-is-exact t) -					   ()) -				       (list "," -					     (substring com -							most-len)))) -				  comps)))))) +		  (alternatives (if most +				    (mapconcat 'iswitchb-output-completion +					       comps ",") +				  (mapconcat 'identity comps ","))))  	     (concat | 
