diff options
author | Nick Roberts <nickrob@snap.net.nz> | 2005-01-12 06:13:08 +0000 |
---|---|---|
committer | Nick Roberts <nickrob@snap.net.nz> | 2005-01-12 06:13:08 +0000 |
commit | bf31a09320c3ec079e8cbb035f20533e8bfa5b7e (patch) | |
tree | 55e185041465e3ffe5fafc0b5b47a60d9636682d /lisp/xt-mouse.el | |
parent | a1c9fd1979349f5ae51ea7600f5c299e349be751 (diff) | |
download | emacs-bf31a09320c3ec079e8cbb035f20533e8bfa5b7e.tar.gz |
(xterm-mouse-translate, xterm-mouse-event): Enable
mouse clicks on mode-line, header-line and margin.
(event-type): Give mouse event symbols an 'event-kind property
with value 'mouse-click.
Diffstat (limited to 'lisp/xt-mouse.el')
-rw-r--r-- | lisp/xt-mouse.el | 50 |
1 files changed, 16 insertions, 34 deletions
diff --git a/lisp/xt-mouse.el b/lisp/xt-mouse.el index 19b58475a93..de93456ad5a 100644 --- a/lisp/xt-mouse.el +++ b/lisp/xt-mouse.el @@ -43,14 +43,17 @@ ;; Support multi-click -- somehow. -;; Clicking on the mode-line does not work, although it should. - ;;; Code: (define-key function-key-map "\e[M" 'xterm-mouse-translate) (defvar xterm-mouse-last) +;; Mouse events symbols must have an 'event-kind property with +;; the value 'mouse-click. +(dolist (event-type '(mouse-1 mouse-2 mouse-3)) + (put event-type 'event-kind 'mouse-click)) + (defun xterm-mouse-translate (event) "Read a click and release event from XTerm." (save-excursion @@ -78,7 +81,7 @@ (click-where (nth 1 click-data))) (if (memq down-binding '(nil ignore)) (if (and (symbolp click-where) - (not (eq 'menu-bar click-where))) + (consp click-where)) (vector (list click-where click-data) click) (vector click)) (setq unread-command-events @@ -92,10 +95,9 @@ 0 (list (intern (format "drag-mouse-%d" (+ 1 xterm-mouse-last))) - down-data click-data)) - ))) + down-data click-data))))) (if (and (symbolp down-where) - (not (eq 'menu-bar down-where))) + (consp down-where)) (vector (list down-where down-data) down) (vector down)))))))) @@ -124,30 +126,6 @@ (let* ((type (- (xterm-mouse-event-read) #o40)) (x (- (xterm-mouse-event-read) #o40 1)) (y (- (xterm-mouse-event-read) #o40 1)) - (point (cons x y)) - (window (window-at x y)) - (where (if window - (coordinates-in-window-p point window) - 'menu-bar)) - (pos (if (consp where) - (progn - (select-window window) - (goto-char (window-start window)) - (move-to-window-line (- - (cdr where) - (if (or header-line-format - default-header-line-format) - 1 - 0))) - (move-to-column (- (+ (car where) (current-column) - (if (string-match "\\` \\*Minibuf" - (buffer-name)) - (- (minibuffer-prompt-width)) - 0) - (max 0 (1- (window-hscroll)))) - left-margin-width)) - (point)) - where)) (mouse (intern ;; For buttons > 3, the release-event looks ;; differently (see xc/programs/xterm/button.c, @@ -159,12 +137,16 @@ (format "mouse-%d" (+ 1 xterm-mouse-last))) (t (setq xterm-mouse-last type) - (format "down-mouse-%d" (+ 1 type))))))) + (format "down-mouse-%d" (+ 1 type)))))) + (w (window-at x y))) (setq xterm-mouse-x x xterm-mouse-y y) - (list mouse - (list window pos point - (/ (nth 2 (current-time)) 1000))))) + (if w + (list mouse (posn-at-x-y x (if menu-bar-mode (- y 1) y) w)) + (list mouse + (append (list nil 'menu-bar) + (nthcdr 2 (posn-at-x-y + x (if menu-bar-mode (- y 1) y) w))))))) ;;;###autoload (define-minor-mode xterm-mouse-mode |