diff options
| author | Eli Zaretskii <eliz@gnu.org> | 2016-09-23 17:25:55 +0300 |
|---|---|---|
| committer | Eli Zaretskii <eliz@gnu.org> | 2016-09-23 17:25:55 +0300 |
| commit | f2819241bc93b641f13e1a04f3520fadb8ed53a8 (patch) | |
| tree | 3a6e010fce25b3d824fb129ea90d3b29b8b41299 /lisp | |
| parent | 7cb120ebf397c51540ebb4ef223d84852394ed58 (diff) | |
| download | emacs-f2819241bc93b641f13e1a04f3520fadb8ed53a8.tar.gz | |
Fix display of cursor when 'blink-cursor-delay' has small value
* lisp/frame.el (blink-cursor-check, blink-cursor-mode):
Protect ourselves against too small values of blink-cursor-delay.
This avoids erratic display of the cursor, or even failure to
display it, when user types text at high speed or leans on a key
to invoke the keyboard auto-repeat feature. (Bug#24372)
Diffstat (limited to 'lisp')
| -rw-r--r-- | lisp/frame.el | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/lisp/frame.el b/lisp/frame.el index 09738d1e2ed..291150b591b 100644 --- a/lisp/frame.el +++ b/lisp/frame.el @@ -2115,7 +2115,11 @@ This is done when a frame gets focus. Blink timers may be stopped by (not blink-cursor-idle-timer)) (remove-hook 'post-command-hook 'blink-cursor-check) (setq blink-cursor-idle-timer - (run-with-idle-timer blink-cursor-delay + ;; The 0.2 sec limitation from below is to avoid erratic + ;; behavior (or downright failure to display the cursor + ;; during command execution) if they set blink-cursor-delay + ;; to a very small or even zero value. + (run-with-idle-timer (max 0.2 blink-cursor-delay) blink-cursor-delay 'blink-cursor-start)))) @@ -2149,7 +2153,11 @@ terminals, cursor blinking is controlled by the terminal." (add-hook 'focus-in-hook #'blink-cursor-check) (add-hook 'focus-out-hook #'blink-cursor-suspend) (setq blink-cursor-idle-timer - (run-with-idle-timer blink-cursor-delay + ;; The 0.2 sec limitation from below is to avoid erratic + ;; behavior (or downright failure to display the cursor + ;; during command execution) if they set blink-cursor-delay + ;; to a very small or even zero value. + (run-with-idle-timer (max 0.2 blink-cursor-delay) blink-cursor-delay #'blink-cursor-start)))) |
