summaryrefslogtreecommitdiff
path: root/lisp
diff options
context:
space:
mode:
authorEli Zaretskii <eliz@gnu.org>2016-09-23 17:25:55 +0300
committerEli Zaretskii <eliz@gnu.org>2016-09-23 17:25:55 +0300
commitf2819241bc93b641f13e1a04f3520fadb8ed53a8 (patch)
tree3a6e010fce25b3d824fb129ea90d3b29b8b41299 /lisp
parent7cb120ebf397c51540ebb4ef223d84852394ed58 (diff)
downloademacs-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.el12
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))))