# HG changeset patch # User Juri Linkov # Date 1206831377 0 # Node ID b532cf17d6ad35b307a98cc405411be41aba24a4 # Parent c15f559a5ada9101a15a0ebc730396171693759a (minibuffer-default-add-function): New variable with the default to minibuffer-default-add-completions. (minibuffer-default-add-done): New variable. Make it buffer-local. (minibuffer-default-add-completions): New function. (goto-history-element): Set minibuffer-default-add-done to t and call a function in minibuffer-default-add-function when the specified absolute history position is greater than the length of the minibuffer-default list and minibuffer-default-add-done is nil. Change "^End of history; no next item$" to "^End of defaults; no next item$". diff -r c15f559a5ada -r b532cf17d6ad lisp/simple.el --- a/lisp/simple.el Sat Mar 29 22:50:11 2008 +0000 +++ b/lisp/simple.el Sat Mar 29 22:56:17 2008 +0000 @@ -1304,10 +1304,49 @@ (defvar minibuffer-temporary-goal-position nil) +(defvar minibuffer-default-add-function 'minibuffer-default-add-completions + "Function run by `goto-history-element' before consuming `minibuffer-default'. +This is useful to dynamically add more elements to the list `minibuffer-default' +when `goto-history-element' reaches the end of this list. +Before calling this function `goto-history-element' sets the variable +`minibuffer-default-add-done' to t, so it will call this function only +once. In special cases, when this function needs to be called more +than once, it can set `minibuffer-default-add-done' to nil explicitly, +overriding the setting of this variable to t in `goto-history-element'.") + +(defvar minibuffer-default-add-done nil + "When nil, add more elements to the end of the list of default values. +The value nil causes `goto-history-element' to add more elements to +the list of defaults when it reaches the end of this list. It does +this by calling a function defined by `minibuffer-default-add-function'.") + +(make-variable-buffer-local 'minibuffer-default-add-done) + +(defun minibuffer-default-add-completions () + "Return a list of all completions without the default value. +This function is used to add all elements of the completion table to +the end of the list of defaults just after the default value." + (interactive) + (let ((def minibuffer-default) + (all (all-completions "" + minibuffer-completion-table + minibuffer-completion-predicate + t))) + (if (listp def) + (append def all) + (cons def (delete def all))))) + (defun goto-history-element (nabs) "Puts element of the minibuffer history in the minibuffer. The argument NABS specifies the absolute history position." (interactive "p") + (when (and (not minibuffer-default-add-done) + (functionp minibuffer-default-add-function) + (< nabs (- (if (listp minibuffer-default) + (length minibuffer-default) + 1)))) + (setq minibuffer-default-add-done t + minibuffer-default (funcall minibuffer-default-add-function))) (let ((minimum (if minibuffer-default (- (if (listp minibuffer-default) (length minibuffer-default) @@ -1320,7 +1359,7 @@ (minibuffer-contents-no-properties))) (if (< nabs minimum) (if minibuffer-default - (error "End of history; no next item") + (error "End of defaults; no next item") (error "End of history; no default available"))) (if (> nabs (length (symbol-value minibuffer-history-variable))) (error "Beginning of history; no preceding item"))