]> code.delx.au - gnu-emacs/blobdiff - lisp/scroll-bar.el
(ispell-highlight-spelling-error): Use
[gnu-emacs] / lisp / scroll-bar.el
index 4499c0b0b5f9ea595ae4e6ebe7a2882b1dda5a6c..b7f2de82a6ef303f303fce218e5143e0a07b1652 100644 (file)
@@ -286,26 +286,13 @@ EVENT should be a scroll bar click."
 \f
 ;;; Tookit scroll bars.
 
-;; Due to its event handling, Emacs is currently not able to handle Xt
-;; timeouts which toolkit scroll bars use to implement auto-repeat.
-;; As a workaround, we start a timer whenever a scroll bar action
-;; occurs, and remove it again when are notified that the user no
-;; longer interacts with the scroll bar.  The timer function gives Xt
-;; the chance to call Xt timeout functions.
-
-(defvar scroll-bar-timer nil
-  "Timer running while scroll bar is active.")
-
 (defun scroll-bar-toolkit-scroll (event)
   (interactive "e")
   (let* ((end-position (event-end event))
         (window (nth 0 end-position))
         (part (nth 4 end-position))
         before-scroll)
-    (cond ((eq part 'end-scroll)
-          (when scroll-bar-timer
-            (cancel-timer scroll-bar-timer)
-            (setq scroll-bar-timer nil)))
+    (cond ((eq part 'end-scroll))
          (t
           (with-current-buffer (window-buffer window)
             (setq before-scroll point-before-scroll))
@@ -316,6 +303,13 @@ EVENT should be a scroll bar click."
                    (scroll-up '-))
                   ((eq part 'below-handle)
                    (scroll-up nil))
+                  ((eq part 'ratio)
+                   (let* ((portion-whole (nth 2 end-position))
+                          (lines (scroll-bar-scale portion-whole
+                                                   (1- (window-height)))))
+                     (scroll-up (cond ((not (zerop lines)) lines)
+                                      ((< (car portion-whole) 0) -1)
+                                      (t 1)))))
                   ((eq part 'up)
                    (scroll-up -1))
                   ((eq part 'down)
@@ -328,9 +322,6 @@ EVENT should be a scroll bar click."
                   ((eq part 'handle)
                    (scroll-bar-drag-1 event))))
           (sit-for 0)
-          (unless scroll-bar-timer
-            (setq scroll-bar-timer
-                  (run-with-timer 0.1 0.1 'xt-process-timeouts)))
           (with-current-buffer (window-buffer window)
             (setq point-before-scroll before-scroll))))))