[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
feature/completions-highlight-modifications 15cfc70 1/6: Insert some mod
From: |
Jimmy Aguilar Mena |
Subject: |
feature/completions-highlight-modifications 15cfc70 1/6: Insert some modifications to implement completions highlighting. |
Date: |
Sat, 14 Nov 2020 21:36:31 -0500 (EST) |
branch: feature/completions-highlight-modifications
commit 15cfc700aadf96e5b87469e44321bb2b60b27033
Author: Jimmy Aguilar Mena <spacibba@aol.com>
Commit: Jimmy Aguilar Mena <spacibba@aol.com>
Insert some modifications to implement completions highlighting.
This are changes needed in the minibuffer API to do highlighting from a
different package.
* lisp/minibuffer.el (minibuffer-tab-through-completions-function) : New
variable containing the action to do when pressing tab in minibuffer
and *Completions* are shown.
(minibuffer-tab-through-completions-default) : Default function value
for minibuffer-tab-through-completions-function.
(completion--in-region-1) : Modification to funcall
minibuffer-tab-through-completions-function.
(minibuffer-hide-completions-hook) : New hook to call after
closing *Completions* buffer.
(minibuffer-hide-completions) : Modify to run hook
minibuffer-hide-completions-hook.
---
lisp/minibuffer.el | 44 +++++++++++++++++++++++++++++++++-----------
1 file changed, 33 insertions(+), 11 deletions(-)
diff --git a/lisp/minibuffer.el b/lisp/minibuffer.el
index 9d57a81..2c97948 100644
--- a/lisp/minibuffer.el
+++ b/lisp/minibuffer.el
@@ -1283,6 +1283,27 @@ scroll the window of possible completions."
minibuffer-completion-table
minibuffer-completion-predicate)))
+
+(defun minibuffer-tab-through-completions-default ()
+ "Default action in `minibuffer-scroll-window' WINDOW.
+This is called when *Completions* window is already visible."
+ (let ((window minibuffer-scroll-window))
+ (with-current-buffer (window-buffer window)
+ (if (pos-visible-in-window-p (point-max) window)
+ ;; If end is in view, scroll up to the beginning.
+ (set-window-start window (point-min) nil)
+ ;; Else scroll down one screen.
+ (with-selected-window window
+ (scroll-up)))
+ nil)))
+
+(defvar minibuffer-tab-through-completions-function
+ #'minibuffer-tab-through-completions-default
+ "Function to execute when requested completion.
+This is used when *Completions* frame is already visible and the
+completions command is called again. This function receives the
+window to execute commands as a paramenter.")
+
(defun completion--in-region-1 (beg end)
;; If the previous command was not this,
;; mark the completion buffer obsolete.
@@ -1290,21 +1311,14 @@ scroll the window of possible completions."
(unless (eq 'completion-at-point last-command)
(completion--flush-all-sorted-completions)
(setq minibuffer-scroll-window nil))
-
(cond
;; If there's a fresh completion window with a live buffer,
;; and this command is repeated, scroll that window.
((and (window-live-p minibuffer-scroll-window)
(eq t (frame-visible-p (window-frame minibuffer-scroll-window))))
- (let ((window minibuffer-scroll-window))
- (with-current-buffer (window-buffer window)
- (if (pos-visible-in-window-p (point-max) window)
- ;; If end is in view, scroll up to the beginning.
- (set-window-start window (point-min) nil)
- ;; Else scroll down one screen.
- (with-selected-window window
- (scroll-up)))
- nil)))
+ ;; Action to perform when pressing tab and completions are shown.
+ (funcall minibuffer-tab-through-completions-function)
+ nil)
;; If we're cycling, keep on cycling.
((and completion-cycling completion-all-sorted-completions)
(minibuffer-force-complete beg end)
@@ -2051,12 +2065,20 @@ variables.")
nil)))
nil))
+(defvar minibuffer-hide-completions-hook nil
+ "Normal hook run at the end of completion-hide-completions.
+The hook is called from the minibuffer after hide completions.
+When this hook is run, the current buffer is the minibuffer and
+the *Completions* buffer is already hidden.")
+
(defun minibuffer-hide-completions ()
"Get rid of an out-of-date *Completions* buffer."
;; FIXME: We could/should use minibuffer-scroll-window here, but it
;; can also point to the minibuffer-parent-window, so it's a bit tricky.
(let ((win (get-buffer-window "*Completions*" 0)))
- (if win (with-selected-window win (bury-buffer)))))
+ (when win
+ (with-selected-window win (bury-buffer))
+ (run-hooks 'minibuffer-hide-completions-hook))))
(defun exit-minibuffer ()
"Terminate this minibuffer argument."
- branch feature/completions-highlight-modifications created (now 55c29ce), Jimmy Aguilar Mena, 2020/11/14
- feature/completions-highlight-modifications e3c5b99 3/6: Add completions-highlight-mode initial implementation., Jimmy Aguilar Mena, 2020/11/14
- feature/completions-highlight-modifications 23a36e9 4/6: Fix initial comment in completions-highlight file., Jimmy Aguilar Mena, 2020/11/14
- feature/completions-highlight-modifications 5f47ef8 5/6: Improve keymap handling., Jimmy Aguilar Mena, 2020/11/14
- feature/completions-highlight-modifications 15cfc70 1/6: Insert some modifications to implement completions highlighting.,
Jimmy Aguilar Mena <=
- feature/completions-highlight-modifications 813dcaf 2/6: Document the changes in the API for Completions., Jimmy Aguilar Mena, 2020/11/14
- feature/completions-highlight-modifications 55c29ce 6/6: Fix recursive set-keymap-parent in completions-highlight., Jimmy Aguilar Mena, 2020/11/14