Skip to content
This repository has been archived by the owner on Jun 25, 2024. It is now read-only.

Fix paging with God mode #247

Open
wants to merge 3 commits into
base: master
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
38 changes: 26 additions & 12 deletions which-key.el
Original file line number Diff line number Diff line change
Expand Up @@ -763,28 +763,42 @@ problems at github.")
(defvar which-key--god-mode-key-string nil
"Holds key string to use for god-mode support.")

(defadvice god-mode-lookup-command
(around which-key--god-mode-lookup-command-advice disable)
(setq which-key--god-mode-key-string (ad-get-arg 0))
(defun which-key--god-mode-lookup-command-advice (orig-fn &rest args)
"Advice function for `god-mode-lookup-command'."
(setq which-key--god-mode-key-string (car args))
(unwind-protect
ad-do-it
(apply orig-fn args)
(when (bound-and-true-p which-key-mode)
(which-key--hide-popup))))

(defun which-key--god-mode-help-char-dispatch (orig-fn &rest args)
"Advice function for `god-mode-help-char-dispatch'."
(if (not (which-key--popup-showing-p))
(apply orig-fn args)
(which-key--stop-timer)
(which-key-C-h-dispatch)
;; Discard last prefix input. `discard-input' cannot be used
;; here as it ends any macro being defined.
(setq unread-command-events nil)
;; Return keys entered so far to prevent quitting current key
;; sequence.
(cadr args)))

(defun which-key-enable-god-mode-support (&optional disable)
"Enable support for god-mode if non-nil. This is experimental,
so you need to explicitly opt-in for now. Please report any
problems at github. If DISABLE is non-nil disable support."
(interactive "P")
(setq which-key--god-mode-support-enabled (null disable))
(if disable
(ad-disable-advice
'god-mode-lookup-command
'around 'which-key--god-mode-lookup-command-advice)
(ad-enable-advice
'god-mode-lookup-command
'around 'which-key--god-mode-lookup-command-advice))
(ad-activate 'god-mode-lookup-command))
(cond (which-key--god-mode-support-enabled
(advice-add 'god-mode-lookup-command
:around #'which-key--god-mode-lookup-command-advice)
(advice-add 'god-mode-help-char-dispatch
:around #'which-key--god-mode-help-char-dispatch))
(t (advice-remove 'god-mode-lookup-command
#'which-key--god-mode-lookup-command-advice)
(advice-remove 'god-mode-help-char-dispatch
#'which-key--god-mode-help-char-dispatch))))

;;; Mode

Expand Down