Mercurial > emacs
annotate lisp/tooltip.el @ 60975:c7c6caacbc9e
(GTK resources): Fix last change.
author | Eli Zaretskii <eliz@gnu.org> |
---|---|
date | Sat, 26 Mar 2005 15:25:26 +0000 |
parents | b39c6b2034fa |
children | dd51ca9ed348 13796b0653c7 |
rev | line source |
---|---|
45236 | 1 ;;; tooltip.el --- show tooltip windows |
25003 | 2 |
60539
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
3 ;; Copyright (C) 1997, 1999, 2000, 2001, 2002, 2003, 2004, 2005 |
59017
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
4 ;; Free Software Foundation, Inc. |
25003 | 5 |
6 ;; Author: Gerd Moellmann <gerd@acm.org> | |
7 ;; Keywords: help c mouse tools | |
8 | |
9 ;; This file is part of GNU Emacs. | |
10 | |
11 ;; GNU Emacs is free software; you can redistribute it and/or modify | |
12 ;; it under the terms of the GNU General Public License as published by | |
13 ;; the Free Software Foundation; either version 2, or (at your option) | |
14 ;; any later version. | |
15 | |
16 ;; GNU Emacs is distributed in the hope that it will be useful, | |
17 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
19 ;; GNU General Public License for more details. | |
20 | |
21 ;; You should have received a copy of the GNU General Public License | |
22 ;; along with GNU Emacs; see the file COPYING. If not, write to the | |
23 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330, | |
24 ;; Boston, MA 02111-1307, USA. | |
25 | |
26 ;;; Commentary: | |
27 | |
28 ;;; Code: | |
29 | |
58163
7048d946d9df
(require): Explain why CL is needed.
Nick Roberts <nickrob@snap.net.nz>
parents:
58155
diff
changeset
|
30 (eval-when-compile (require 'cl)) ; for case macro |
58155 | 31 |
25003 | 32 |
33 ;;; Customizable settings | |
34 | |
35 (defgroup tooltip nil | |
36 "Customization group for the `tooltip' package." | |
37 :group 'help | |
37755
cf803b8f08ad
(tooltip) <defgroup>: Put it in `gud' group instead
Gerd Moellmann <gerd@gnu.org>
parents:
35401
diff
changeset
|
38 :group 'gud |
25003 | 39 :group 'mouse |
40 :group 'tools | |
25332
c09e05be2f4b
(tooltip-mode): Customize this, per convention.
Dave Love <fx@gnu.org>
parents:
25003
diff
changeset
|
41 :version "21.1" |
25003 | 42 :tag "Tool Tips") |
43 | |
40679
3c4df1ce9e4c
(tooltip-delay): Decrease to 0.7.
Eli Zaretskii <eliz@gnu.org>
parents:
40376
diff
changeset
|
44 (defcustom tooltip-delay 0.7 |
25003 | 45 "Seconds to wait before displaying a tooltip the first time." |
46 :tag "Delay" | |
47 :type 'number | |
48 :group 'tooltip) | |
49 | |
50 (defcustom tooltip-short-delay 0.1 | |
51 "Seconds to wait between subsequent tooltips on different items." | |
52 :tag "Short delay" | |
53 :type 'number | |
54 :group 'tooltip) | |
55 | |
56 (defcustom tooltip-recent-seconds 1 | |
25332
c09e05be2f4b
(tooltip-mode): Customize this, per convention.
Dave Love <fx@gnu.org>
parents:
25003
diff
changeset
|
57 "Display tooltips if changing tip items within this many seconds. |
c09e05be2f4b
(tooltip-mode): Customize this, per convention.
Dave Love <fx@gnu.org>
parents:
25003
diff
changeset
|
58 Do so after `tooltip-short-delay'." |
25003 | 59 :tag "Recent seconds" |
60 :type 'number | |
61 :group 'tooltip) | |
62 | |
40679
3c4df1ce9e4c
(tooltip-delay): Decrease to 0.7.
Eli Zaretskii <eliz@gnu.org>
parents:
40376
diff
changeset
|
63 (defcustom tooltip-hide-delay 10 |
35401
c00e94a506a2
(tooltip-hide-delay): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents:
35069
diff
changeset
|
64 "Hide tooltips automatically after this many seconds." |
c00e94a506a2
(tooltip-hide-delay): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents:
35069
diff
changeset
|
65 :tag "Hide delay" |
c00e94a506a2
(tooltip-hide-delay): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents:
35069
diff
changeset
|
66 :type 'number |
c00e94a506a2
(tooltip-hide-delay): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents:
35069
diff
changeset
|
67 :group 'tooltip) |
c00e94a506a2
(tooltip-hide-delay): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents:
35069
diff
changeset
|
68 |
33587
7d4c3fcd3421
(tooltip-x-offset, tooltip-y-offset): New user-options.
Gerd Moellmann <gerd@gnu.org>
parents:
33356
diff
changeset
|
69 (defcustom tooltip-x-offset nil |
46025
ce0d438fe05e
(tooltip-x-offset, tooltip-y-offset): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents:
45571
diff
changeset
|
70 "X offset, in pixels, for the display of tooltips. |
33587
7d4c3fcd3421
(tooltip-x-offset, tooltip-y-offset): New user-options.
Gerd Moellmann <gerd@gnu.org>
parents:
33356
diff
changeset
|
71 The offset is relative to the position of the mouse. It must |
7d4c3fcd3421
(tooltip-x-offset, tooltip-y-offset): New user-options.
Gerd Moellmann <gerd@gnu.org>
parents:
33356
diff
changeset
|
72 be chosen so that the tooltip window doesn't contain the mouse |
40173
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
73 when it pops up. If the value is nil, the default offset is 5 |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
74 pixels. |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
75 |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
76 If `tooltip-frame-parameters' includes the `left' parameter, |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
77 the value of `tooltip-x-offset' is ignored." |
33587
7d4c3fcd3421
(tooltip-x-offset, tooltip-y-offset): New user-options.
Gerd Moellmann <gerd@gnu.org>
parents:
33356
diff
changeset
|
78 :tag "X offset" |
7d4c3fcd3421
(tooltip-x-offset, tooltip-y-offset): New user-options.
Gerd Moellmann <gerd@gnu.org>
parents:
33356
diff
changeset
|
79 :type '(choice (const :tag "Default" nil) |
7d4c3fcd3421
(tooltip-x-offset, tooltip-y-offset): New user-options.
Gerd Moellmann <gerd@gnu.org>
parents:
33356
diff
changeset
|
80 (integer :tag "Offset" :value 1)) |
7d4c3fcd3421
(tooltip-x-offset, tooltip-y-offset): New user-options.
Gerd Moellmann <gerd@gnu.org>
parents:
33356
diff
changeset
|
81 :group 'tooltip) |
7d4c3fcd3421
(tooltip-x-offset, tooltip-y-offset): New user-options.
Gerd Moellmann <gerd@gnu.org>
parents:
33356
diff
changeset
|
82 |
7d4c3fcd3421
(tooltip-x-offset, tooltip-y-offset): New user-options.
Gerd Moellmann <gerd@gnu.org>
parents:
33356
diff
changeset
|
83 (defcustom tooltip-y-offset nil |
46025
ce0d438fe05e
(tooltip-x-offset, tooltip-y-offset): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents:
45571
diff
changeset
|
84 "Y offset, in pixels, for the display of tooltips. |
33587
7d4c3fcd3421
(tooltip-x-offset, tooltip-y-offset): New user-options.
Gerd Moellmann <gerd@gnu.org>
parents:
33356
diff
changeset
|
85 The offset is relative to the position of the mouse. It must |
7d4c3fcd3421
(tooltip-x-offset, tooltip-y-offset): New user-options.
Gerd Moellmann <gerd@gnu.org>
parents:
33356
diff
changeset
|
86 be chosen so that the tooltip window doesn't contain the mouse |
40173
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
87 when it pops up. If the value is nil, the default offset is -10 |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
88 pixels. |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
89 |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
90 If `tooltip-frame-parameters' includes the `top' parameter, |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
91 the value of `tooltip-y-offset' is ignored." |
33587
7d4c3fcd3421
(tooltip-x-offset, tooltip-y-offset): New user-options.
Gerd Moellmann <gerd@gnu.org>
parents:
33356
diff
changeset
|
92 :tag "Y offset" |
7d4c3fcd3421
(tooltip-x-offset, tooltip-y-offset): New user-options.
Gerd Moellmann <gerd@gnu.org>
parents:
33356
diff
changeset
|
93 :type '(choice (const :tag "Default" nil) |
7d4c3fcd3421
(tooltip-x-offset, tooltip-y-offset): New user-options.
Gerd Moellmann <gerd@gnu.org>
parents:
33356
diff
changeset
|
94 (integer :tag "Offset" :value 1)) |
7d4c3fcd3421
(tooltip-x-offset, tooltip-y-offset): New user-options.
Gerd Moellmann <gerd@gnu.org>
parents:
33356
diff
changeset
|
95 :group 'tooltip) |
7d4c3fcd3421
(tooltip-x-offset, tooltip-y-offset): New user-options.
Gerd Moellmann <gerd@gnu.org>
parents:
33356
diff
changeset
|
96 |
25003 | 97 (defcustom tooltip-frame-parameters |
98 '((name . "tooltip") | |
99 (internal-border-width . 5) | |
100 (border-width . 1)) | |
40173
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
101 "Frame parameters used for tooltips. |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
102 |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
103 If `left' or `top' parameters are included, they specify the absolute |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
104 position to pop up the tooltip." |
25003 | 105 :type 'sexp |
106 :tag "Frame Parameters" | |
107 :group 'tooltip) | |
108 | |
35043
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
109 (defface tooltip |
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
110 '((((class color)) |
52031
5163fa137977
(defface tooltip): Inherit from variable-pitch.
John Paul Wallington <jpw@pobox.com>
parents:
49597
diff
changeset
|
111 :background "lightyellow" |
5163fa137977
(defface tooltip): Inherit from variable-pitch.
John Paul Wallington <jpw@pobox.com>
parents:
49597
diff
changeset
|
112 :foreground "black" |
5163fa137977
(defface tooltip): Inherit from variable-pitch.
John Paul Wallington <jpw@pobox.com>
parents:
49597
diff
changeset
|
113 :inherit variable-pitch) |
5163fa137977
(defface tooltip): Inherit from variable-pitch.
John Paul Wallington <jpw@pobox.com>
parents:
49597
diff
changeset
|
114 (t |
5163fa137977
(defface tooltip): Inherit from variable-pitch.
John Paul Wallington <jpw@pobox.com>
parents:
49597
diff
changeset
|
115 :inherit variable-pitch)) |
35043
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
116 "Face for tooltips." |
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
117 :group 'tooltip) |
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
118 |
25003 | 119 (defcustom tooltip-gud-tips-p nil |
48651
572f41d9a2ea
(tooltip-gud-tips-p): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents:
48601
diff
changeset
|
120 "*Non-nil means show tooltips in GUD sessions." |
25003 | 121 :type 'boolean |
122 :tag "GUD" | |
123 :group 'tooltip) | |
124 | |
60539
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
125 (defcustom tooltip-gud-modes '(gud-mode c-mode c++-mode fortran-mode) |
25003 | 126 "List of modes for which to enable GUD tips." |
127 :type 'sexp | |
128 :tag "GUD modes" | |
129 :group 'tooltip) | |
130 | |
131 (defcustom tooltip-gud-display | |
132 '((eq (tooltip-event-buffer tooltip-gud-event) | |
133 (marker-buffer overlay-arrow-position))) | |
134 "List of forms determining where GUD tooltips are displayed. | |
135 | |
136 Forms in the list are combined with AND. The default is to display | |
137 only tooltips in the buffer containing the overlay arrow." | |
138 :type 'sexp | |
139 :tag "GUD buffers predicate" | |
140 :group 'tooltip) | |
141 | |
32431
a35cc9700ff7
* tooltip.el (tooltip-use-echo-area): New user variable.
Sam Steingold <sds@gnu.org>
parents:
30481
diff
changeset
|
142 (defcustom tooltip-use-echo-area nil |
33923 | 143 "Use the echo area instead of tooltip frames. |
144 This is only relevant GUD display, since otherwise it is equivalent to | |
145 turning off Tooltip mode." | |
32431
a35cc9700ff7
* tooltip.el (tooltip-use-echo-area): New user variable.
Sam Steingold <sds@gnu.org>
parents:
30481
diff
changeset
|
146 :type 'boolean |
33925 | 147 :tag "Use echo area" |
32431
a35cc9700ff7
* tooltip.el (tooltip-use-echo-area): New user variable.
Sam Steingold <sds@gnu.org>
parents:
30481
diff
changeset
|
148 :group 'tooltip) |
a35cc9700ff7
* tooltip.el (tooltip-use-echo-area): New user variable.
Sam Steingold <sds@gnu.org>
parents:
30481
diff
changeset
|
149 |
25003 | 150 |
151 ;;; Variables that are not customizable. | |
152 | |
153 (defvar tooltip-hook nil | |
154 "Functions to call to display tooltips. | |
155 Each function is called with one argument EVENT which is a copy of | |
156 the last mouse movement event that occurred.") | |
157 | |
158 (defvar tooltip-timeout-id nil | |
159 "The id of the timeout started when Emacs becomes idle.") | |
160 | |
161 (defvar tooltip-last-mouse-motion-event nil | |
162 "A copy of the last mouse motion event seen.") | |
163 | |
164 (defvar tooltip-hide-time nil | |
165 "Time when the last tooltip was hidden.") | |
166 | |
167 | |
168 ;;; Event accessors | |
169 | |
170 (defun tooltip-event-buffer (event) | |
171 "Return the buffer over which event EVENT occurred. | |
172 This might return nil if the event did not occur over a buffer." | |
173 (let ((window (posn-window (event-end event)))) | |
174 (and window (window-buffer window)))) | |
175 | |
176 | |
177 ;;; Switching tooltips on/off | |
178 | |
179 ;; We don't set track-mouse globally because this is a big redisplay | |
180 ;; problem in buffers having a pre-command-hook or such installed, | |
181 ;; which does a set-buffer, like the summary buffer of Gnus. Calling | |
182 ;; set-buffer prevents redisplay optimizations, so every mouse motion | |
183 ;; would be accompanied by a full redisplay. | |
184 | |
185 ;;;###autoload | |
60539
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
186 (define-minor-mode tooltip-mode |
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
187 "Toggle Tooltip display. |
25003 | 188 With ARG, turn tooltip mode on if and only if ARG is positive." |
60539
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
189 :global t |
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
190 :group 'tooltip |
60547
23b4e52963d6
(tooltip-mode): Don't complain that you can't turn the
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
60539
diff
changeset
|
191 (unless (or (null tooltip-mode) (fboundp 'x-show-tip)) |
34689
e045e0e60223
(tooltip-mode): Signal an error if x-show-tip
Gerd Moellmann <gerd@gnu.org>
parents:
34540
diff
changeset
|
192 (error "Sorry, tooltips are not yet available on this system")) |
60539
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
193 (let ((hook-fn (if tooltip-mode 'add-hook 'remove-hook))) |
25003 | 194 (funcall hook-fn 'change-major-mode-hook 'tooltip-change-major-mode) |
195 (tooltip-activate-mouse-motions-if-enabled) | |
196 (funcall hook-fn 'pre-command-hook 'tooltip-hide) | |
197 (funcall hook-fn 'tooltip-hook 'tooltip-gud-tips) | |
198 (funcall hook-fn 'tooltip-hook 'tooltip-help-tips) | |
60539
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
199 (setq show-help-function (if tooltip-mode 'tooltip-show-help-function nil)) |
25003 | 200 ;; `ignore' is the default binding for mouse movements. |
201 (define-key global-map [mouse-movement] | |
60539
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
202 (if tooltip-mode 'tooltip-mouse-motion 'ignore)))) |
25003 | 203 |
204 | |
205 ;;; Timeout for tooltip display | |
206 | |
207 (defun tooltip-delay () | |
208 "Return the delay in seconds for the next tooltip." | |
209 (let ((delay tooltip-delay) | |
30481 | 210 (now (float-time))) |
25003 | 211 (when (and tooltip-hide-time |
212 (< (- now tooltip-hide-time) tooltip-recent-seconds)) | |
213 (setq delay tooltip-short-delay)) | |
214 delay)) | |
215 | |
35069
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
216 (defun tooltip-cancel-delayed-tip () |
25003 | 217 "Disable the tooltip timeout." |
218 (when tooltip-timeout-id | |
219 (disable-timeout tooltip-timeout-id) | |
220 (setq tooltip-timeout-id nil))) | |
221 | |
35069
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
222 (defun tooltip-start-delayed-tip () |
25003 | 223 "Add a one-shot timeout to call function tooltip-timeout." |
224 (setq tooltip-timeout-id | |
225 (add-timeout (tooltip-delay) 'tooltip-timeout nil))) | |
226 | |
227 (defun tooltip-timeout (object) | |
228 "Function called when timer with id tooltip-timeout-id fires." | |
229 (run-hook-with-args-until-success 'tooltip-hook | |
230 tooltip-last-mouse-motion-event)) | |
231 | |
232 | |
233 ;;; Reacting on mouse movements | |
234 | |
235 (defun tooltip-change-major-mode () | |
236 "Function added to `change-major-mode-hook' when tooltip mode is on." | |
237 (add-hook 'post-command-hook 'tooltip-activate-mouse-motions-if-enabled)) | |
238 | |
239 (defun tooltip-activate-mouse-motions-if-enabled () | |
240 "Reconsider for all buffers whether mouse motion events are desired." | |
241 (remove-hook 'post-command-hook 'tooltip-activate-mouse-motions-if-enabled) | |
60539
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
242 (dolist (buffer (buffer-list)) |
25003 | 243 (save-excursion |
60539
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
244 (set-buffer buffer) |
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
245 (if (and tooltip-mode |
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
246 tooltip-gud-tips-p |
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
247 (memq major-mode tooltip-gud-modes)) |
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
248 (tooltip-activate-mouse-motions t) |
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
249 (tooltip-activate-mouse-motions nil))))) |
25003 | 250 |
45571
04484b8dacdc
(tooltip-mouse-motions-active): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
45236
diff
changeset
|
251 (defvar tooltip-mouse-motions-active nil |
04484b8dacdc
(tooltip-mouse-motions-active): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
45236
diff
changeset
|
252 "Locally t in a buffer if tooltip processing of mouse motion is enabled.") |
25003 | 253 |
254 (defun tooltip-activate-mouse-motions (activatep) | |
255 "Activate/deactivate mouse motion events for the current buffer. | |
256 ACTIVATEP non-nil means activate mouse motion events." | |
257 (if activatep | |
258 (progn | |
45571
04484b8dacdc
(tooltip-mouse-motions-active): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
45236
diff
changeset
|
259 (make-local-variable 'tooltip-mouse-motions-active) |
04484b8dacdc
(tooltip-mouse-motions-active): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
45236
diff
changeset
|
260 (setq tooltip-mouse-motions-active t) |
25003 | 261 (make-local-variable 'track-mouse) |
262 (setq track-mouse t)) | |
45571
04484b8dacdc
(tooltip-mouse-motions-active): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
45236
diff
changeset
|
263 (when tooltip-mouse-motions-active |
04484b8dacdc
(tooltip-mouse-motions-active): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
45236
diff
changeset
|
264 (kill-local-variable 'tooltip-mouse-motions-active) |
04484b8dacdc
(tooltip-mouse-motions-active): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
45236
diff
changeset
|
265 (kill-local-variable 'track-mouse)))) |
25003 | 266 |
267 (defun tooltip-mouse-motion (event) | |
268 "Command handler for mouse movement events in `global-map'." | |
269 (interactive "e") | |
270 (tooltip-hide) | |
271 (when (car (mouse-pixel-position)) | |
272 (setq tooltip-last-mouse-motion-event (copy-sequence event)) | |
35069
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
273 (tooltip-start-delayed-tip))) |
25003 | 274 |
275 | |
276 ;;; Displaying tips | |
277 | |
35043
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
278 (defun tooltip-set-param (alist key value) |
40178
1dab42ecd751
(tooltip-set-param): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents:
40173
diff
changeset
|
279 "Change the value of KEY in alist ALIST to VALUE. |
49597
e88404e8f2cf
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48925
diff
changeset
|
280 If there's no association for KEY in ALIST, add one, otherwise |
35043
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
281 change the existing association. Value is the resulting alist." |
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
282 (let ((param (assq key alist))) |
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
283 (if (consp param) |
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
284 (setcdr param value) |
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
285 (push (cons key value) alist)) |
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
286 alist)) |
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
287 |
25003 | 288 (defun tooltip-show (text) |
40173
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
289 "Show a tooltip window displaying TEXT. |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
290 |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
291 Text larger than `x-max-tooltip-size' (which see) is clipped. |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
292 |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
293 If the alist in `tooltip-frame-parameters' includes `left' and `top' |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
294 parameters, they determine the x and y position where the tooltip |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
295 is displayed. Otherwise, the tooltip pops at offsets specified by |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
296 `tooltip-x-offset' and `tooltip-y-offset' from the current mouse |
c4955867228d
(tooltip-x-offset, tooltip-y-offset): Mention in the
Eli Zaretskii <eliz@gnu.org>
parents:
37755
diff
changeset
|
297 position." |
32431
a35cc9700ff7
* tooltip.el (tooltip-use-echo-area): New user variable.
Sam Steingold <sds@gnu.org>
parents:
30481
diff
changeset
|
298 (if tooltip-use-echo-area |
a35cc9700ff7
* tooltip.el (tooltip-use-echo-area): New user variable.
Sam Steingold <sds@gnu.org>
parents:
30481
diff
changeset
|
299 (message "%s" text) |
34540
e1e4704de6ed
(tooltip-show): If an error is signaled in
Gerd Moellmann <gerd@gnu.org>
parents:
33925
diff
changeset
|
300 (condition-case error |
35043
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
301 (let ((params (copy-sequence tooltip-frame-parameters)) |
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
302 (fg (face-attribute 'tooltip :foreground)) |
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
303 (bg (face-attribute 'tooltip :background))) |
35069
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
304 (when (stringp fg) |
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
305 (setq params (tooltip-set-param params 'foreground-color fg)) |
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
306 (setq params (tooltip-set-param params 'border-color fg))) |
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
307 (when (stringp bg) |
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
308 (setq params (tooltip-set-param params 'background-color bg))) |
35043
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
309 (x-show-tip (propertize text 'face 'tooltip) |
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
310 (selected-frame) |
35044 | 311 params |
35401
c00e94a506a2
(tooltip-hide-delay): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents:
35069
diff
changeset
|
312 tooltip-hide-delay |
35043
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
313 tooltip-x-offset |
f7ca93e40e16
(tooltip-frame-parameters): Remove colors.
Gerd Moellmann <gerd@gnu.org>
parents:
34689
diff
changeset
|
314 tooltip-y-offset)) |
49597
e88404e8f2cf
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48925
diff
changeset
|
315 (error |
34540
e1e4704de6ed
(tooltip-show): If an error is signaled in
Gerd Moellmann <gerd@gnu.org>
parents:
33925
diff
changeset
|
316 (message "Error while displaying tooltip: %s" error) |
e1e4704de6ed
(tooltip-show): If an error is signaled in
Gerd Moellmann <gerd@gnu.org>
parents:
33925
diff
changeset
|
317 (sit-for 1) |
e1e4704de6ed
(tooltip-show): If an error is signaled in
Gerd Moellmann <gerd@gnu.org>
parents:
33925
diff
changeset
|
318 (message "%s" text))))) |
e1e4704de6ed
(tooltip-show): If an error is signaled in
Gerd Moellmann <gerd@gnu.org>
parents:
33925
diff
changeset
|
319 |
25003 | 320 (defun tooltip-hide (&optional ignored-arg) |
321 "Hide a tooltip, if one is displayed. | |
322 Value is non-nil if tooltip was open." | |
35069
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
323 (tooltip-cancel-delayed-tip) |
25003 | 324 (when (x-hide-tip) |
30481 | 325 (setq tooltip-hide-time (float-time)))) |
25003 | 326 |
327 | |
328 ;;; Debugger-related functions | |
329 | |
330 (defun tooltip-identifier-from-point (point) | |
331 "Extract the identifier at POINT, if any. | |
332 Value is nil if no identifier exists at point. Identifier extraction | |
333 is based on the current syntax table." | |
334 (save-excursion | |
335 (goto-char point) | |
336 (let ((start (progn (skip-syntax-backward "w_") (point)))) | |
337 (unless (looking-at "[0-9]") | |
338 (skip-syntax-forward "w_") | |
339 (when (> (point) start) | |
340 (buffer-substring start (point))))))) | |
341 | |
342 (defmacro tooltip-region-active-p () | |
343 "Value is non-nil if the region is currently active." | |
344 (if (string-match "^GNU" (emacs-version)) | |
345 `(and transient-mark-mode mark-active) | |
346 `(region-active-p))) | |
347 | |
348 (defun tooltip-expr-to-print (event) | |
349 "Return an expression that should be printed for EVENT. | |
350 If a region is active and the mouse is inside the region, print | |
351 the region. Otherwise, figure out the identifier around the point | |
352 where the mouse is." | |
353 (save-excursion | |
354 (set-buffer (tooltip-event-buffer event)) | |
355 (let ((point (posn-point (event-end event)))) | |
356 (if (tooltip-region-active-p) | |
357 (when (and (<= (region-beginning) point) (<= point (region-end))) | |
358 (buffer-substring (region-beginning) (region-end))) | |
359 (tooltip-identifier-from-point point))))) | |
360 | |
361 (defun tooltip-process-prompt-regexp (process) | |
362 "Return regexp matching the prompt of PROCESS at the end of a string. | |
363 The prompt is taken from the value of COMINT-PROMPT-REGEXP in the buffer | |
364 of PROCESS." | |
365 (let ((prompt-regexp (save-excursion | |
366 (set-buffer (process-buffer process)) | |
367 comint-prompt-regexp))) | |
368 ;; Most start with `^' but the one for `sdb' cannot be easily | |
369 ;; stripped. Code the prompt for `sdb' fixed here. | |
370 (if (= (aref prompt-regexp 0) ?^) | |
371 (setq prompt-regexp (substring prompt-regexp 1)) | |
372 (setq prompt-regexp "\\*")) | |
373 (concat "\n*" prompt-regexp "$"))) | |
374 | |
375 (defun tooltip-strip-prompt (process output) | |
376 "Return OUTPUT with any prompt of PROCESS stripped from its end." | |
377 (let ((prompt-regexp (tooltip-process-prompt-regexp process))) | |
378 (save-match-data | |
379 (when (string-match prompt-regexp output) | |
380 (setq output (substring output 0 (match-beginning 0))))) | |
381 output)) | |
382 | |
383 | |
384 ;;; Tips for `gud' | |
385 | |
386 (defvar tooltip-gud-original-filter nil | |
387 "Process filter to restore after GUD output has been received.") | |
388 | |
389 (defvar tooltip-gud-dereference nil | |
390 "Non-nil means print expressions with a `*' in front of them. | |
391 For C this would dereference a pointer expression.") | |
392 | |
393 (defvar tooltip-gud-event nil | |
394 "The mouse movement event that led to a tooltip display. | |
395 This event can be examined by forms in TOOLTIP-GUD-DISPLAY.") | |
396 | |
397 (defun tooltip-gud-toggle-dereference () | |
27582
42b52d8b6703
(tooltip-gud-tips-p, tooltip-gud-toggle-dereference):
Dave Love <fx@gnu.org>
parents:
25332
diff
changeset
|
398 "Toggle whether tooltips should show `* expr' or `expr'." |
25003 | 399 (interactive) |
400 (setq tooltip-gud-dereference (not tooltip-gud-dereference)) | |
401 (when (interactive-p) | |
402 (message "Dereferencing is now %s." | |
403 (if tooltip-gud-dereference "on" "off")))) | |
404 | |
49597
e88404e8f2cf
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48925
diff
changeset
|
405 ; This will only display data that comes in one chunk. |
48601
ac47e19224b0
(tooltip-gud-process-output): Handle annotations that
Nick Roberts <nickrob@snap.net.nz>
parents:
48580
diff
changeset
|
406 ; Larger arrays (say 400 elements) are displayed in |
48925
cd1c70649388
(tooltip-gud-tips): Output tooltip without switching
Nick Roberts <nickrob@snap.net.nz>
parents:
48651
diff
changeset
|
407 ; the tootip incompletely and spill over into the gud buffer. |
48601
ac47e19224b0
(tooltip-gud-process-output): Handle annotations that
Nick Roberts <nickrob@snap.net.nz>
parents:
48580
diff
changeset
|
408 ; Switching the process-filter creates timing problems and |
48925
cd1c70649388
(tooltip-gud-tips): Output tooltip without switching
Nick Roberts <nickrob@snap.net.nz>
parents:
48651
diff
changeset
|
409 ; it may be difficult to do better. gdba in gdb-ui.el |
cd1c70649388
(tooltip-gud-tips): Output tooltip without switching
Nick Roberts <nickrob@snap.net.nz>
parents:
48651
diff
changeset
|
410 ; gets round this problem. |
25003 | 411 (defun tooltip-gud-process-output (process output) |
412 "Process debugger output and show it in a tooltip window." | |
413 (set-process-filter process tooltip-gud-original-filter) | |
48925
cd1c70649388
(tooltip-gud-tips): Output tooltip without switching
Nick Roberts <nickrob@snap.net.nz>
parents:
48651
diff
changeset
|
414 (tooltip-show (tooltip-strip-prompt process output))) |
25003 | 415 |
416 (defun tooltip-gud-print-command (expr) | |
417 "Return a suitable command to print the expression EXPR. | |
418 If TOOLTIP-GUD-DEREFERENCE is t, also prepend a `*' to EXPR." | |
419 (when tooltip-gud-dereference | |
420 (setq expr (concat "*" expr))) | |
48572
67d16fb6f6c8
(tooltip-gud-tips-setup): Remove.
Nick Roberts <nickrob@snap.net.nz>
parents:
48517
diff
changeset
|
421 (case gud-minor-mode |
67d16fb6f6c8
(tooltip-gud-tips-setup): Remove.
Nick Roberts <nickrob@snap.net.nz>
parents:
48517
diff
changeset
|
422 ((gdb gdba) (concat "server print " expr)) |
48517
2941d71711f3
(tooltip-gud-print-command): Add server prefix to the
Nick Roberts <nickrob@snap.net.nz>
parents:
46025
diff
changeset
|
423 (dbx (concat "print " expr)) |
25003 | 424 (xdb (concat "p " expr)) |
425 (sdb (concat expr "/")) | |
426 (perldb expr))) | |
30481 | 427 |
25003 | 428 (defun tooltip-gud-tips (event) |
25332
c09e05be2f4b
(tooltip-mode): Customize this, per convention.
Dave Love <fx@gnu.org>
parents:
25003
diff
changeset
|
429 "Show tip for identifier or selection under the mouse. |
c09e05be2f4b
(tooltip-mode): Customize this, per convention.
Dave Love <fx@gnu.org>
parents:
25003
diff
changeset
|
430 The mouse must either point at an identifier or inside a selected |
c09e05be2f4b
(tooltip-mode): Customize this, per convention.
Dave Love <fx@gnu.org>
parents:
25003
diff
changeset
|
431 region for the tip window to be shown. If tooltip-gud-dereference is t, |
c09e05be2f4b
(tooltip-mode): Customize this, per convention.
Dave Love <fx@gnu.org>
parents:
25003
diff
changeset
|
432 add a `*' in front of the printed expression. |
25003 | 433 |
434 This function must return nil if it doesn't handle EVENT." | |
60539
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
435 (let (process) |
25003 | 436 (when (and (eventp event) |
437 tooltip-gud-tips-p | |
438 (boundp 'gud-comint-buffer) | |
60539
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
439 (setq process (get-buffer-process gud-comint-buffer)) |
25003 | 440 (posn-point (event-end event)) |
441 (progn (setq tooltip-gud-event event) | |
442 (eval (cons 'and tooltip-gud-display)))) | |
443 (let ((expr (tooltip-expr-to-print event))) | |
444 (when expr | |
33140
61f4c87b845c
(tooltip-gud-tips-setup): New function.
Miles Bader <miles@gnu.org>
parents:
32431
diff
changeset
|
445 (let ((cmd (tooltip-gud-print-command expr))) |
61f4c87b845c
(tooltip-gud-tips-setup): New function.
Miles Bader <miles@gnu.org>
parents:
32431
diff
changeset
|
446 (unless (null cmd) ; CMD can be nil if unknown debugger |
48925
cd1c70649388
(tooltip-gud-tips): Output tooltip without switching
Nick Roberts <nickrob@snap.net.nz>
parents:
48651
diff
changeset
|
447 (case gud-minor-mode |
49597
e88404e8f2cf
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48925
diff
changeset
|
448 (gdba (gdb-enqueue-input |
48925
cd1c70649388
(tooltip-gud-tips): Output tooltip without switching
Nick Roberts <nickrob@snap.net.nz>
parents:
48651
diff
changeset
|
449 (list (concat cmd "\n") 'gdb-tooltip-print))) |
49597
e88404e8f2cf
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48925
diff
changeset
|
450 (t |
48925
cd1c70649388
(tooltip-gud-tips): Output tooltip without switching
Nick Roberts <nickrob@snap.net.nz>
parents:
48651
diff
changeset
|
451 (setq tooltip-gud-original-filter (process-filter process)) |
cd1c70649388
(tooltip-gud-tips): Output tooltip without switching
Nick Roberts <nickrob@snap.net.nz>
parents:
48651
diff
changeset
|
452 (set-process-filter process 'tooltip-gud-process-output) |
cd1c70649388
(tooltip-gud-tips): Output tooltip without switching
Nick Roberts <nickrob@snap.net.nz>
parents:
48651
diff
changeset
|
453 (gud-basic-call cmd))) |
cd1c70649388
(tooltip-gud-tips): Output tooltip without switching
Nick Roberts <nickrob@snap.net.nz>
parents:
48651
diff
changeset
|
454 expr))))))) |
cd1c70649388
(tooltip-gud-tips): Output tooltip without switching
Nick Roberts <nickrob@snap.net.nz>
parents:
48651
diff
changeset
|
455 |
cd1c70649388
(tooltip-gud-tips): Output tooltip without switching
Nick Roberts <nickrob@snap.net.nz>
parents:
48651
diff
changeset
|
456 (defun gdb-tooltip-print () |
60808
9afb7c1de631
(tooltip-show-help-function): Check car and cdr of
Kim F. Storm <storm@cua.dk>
parents:
60547
diff
changeset
|
457 (tooltip-show |
48925
cd1c70649388
(tooltip-gud-tips): Output tooltip without switching
Nick Roberts <nickrob@snap.net.nz>
parents:
48651
diff
changeset
|
458 (with-current-buffer (gdb-get-buffer 'gdb-partial-output-buffer) |
60539
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
459 (let ((string (buffer-string))) |
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
460 ;; remove newline for tooltip-use-echo-area |
60737ce5edc8
(tooltip-mode): Use define-minor-mode and simplify.
Nick Roberts <nickrob@snap.net.nz>
parents:
60205
diff
changeset
|
461 (substring string 0 (- (length string) 1)))))) |
25003 | 462 |
463 | |
464 ;;; Tooltip help. | |
465 | |
466 (defvar tooltip-help-message nil | |
467 "The last help message received via `tooltip-show-help-function'.") | |
468 | |
469 (defun tooltip-show-help-function (msg) | |
470 "Function installed as `show-help-function'. | |
471 MSG is either a help string to display, or nil to cancel the display." | |
59017
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
472 (let ((previous-help tooltip-help-message) |
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
473 mp pos) |
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
474 (if (and mouse-1-click-follows-link |
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
475 (stringp msg) |
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
476 (save-match-data |
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
477 (string-match "^mouse-2" msg)) |
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
478 (setq mp (mouse-pixel-position)) |
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
479 (consp (setq pos (cdr mp))) |
60832
b39c6b2034fa
(tooltip-show-help-function): Ignore negative mouse
Kim F. Storm <storm@cua.dk>
parents:
60808
diff
changeset
|
480 (car pos) (>= (car pos) 0) |
b39c6b2034fa
(tooltip-show-help-function): Ignore negative mouse
Kim F. Storm <storm@cua.dk>
parents:
60808
diff
changeset
|
481 (cdr pos) (>= (cdr pos) 0) |
59017
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
482 (setq pos (posn-at-x-y (car pos) (cdr pos) (car mp))) |
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
483 (windowp (posn-window pos))) |
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
484 (with-current-buffer (window-buffer (posn-window pos)) |
60205
3af3548ad26d
(tooltip-show-help-function): Pass event to
Kim F. Storm <storm@cua.dk>
parents:
59017
diff
changeset
|
485 (if (mouse-on-link-p pos) |
59017
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
486 (setq msg (concat |
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
487 (cond |
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
488 ((eq mouse-1-click-follows-link 'double) "double-") |
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
489 ((and (integerp mouse-1-click-follows-link) |
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
490 (< mouse-1-click-follows-link 0)) "Long ") |
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
491 (t "")) |
3d934eda2724
(tooltip-show-help-function): Replace "mouse-2"
Kim F. Storm <storm@cua.dk>
parents:
58488
diff
changeset
|
492 "mouse-1" (substring msg 7)))))) |
25003 | 493 (setq tooltip-help-message msg) |
494 (cond ((null msg) | |
35069
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
495 ;; Cancel display. This also cancels a delayed tip, if |
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
496 ;; there is one. |
25003 | 497 (tooltip-hide)) |
35069
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
498 ((equal previous-help msg) |
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
499 ;; Same help as before (but possibly the mouse has moved). |
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
500 ;; Keep what we have. |
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
501 ) |
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
502 (t |
49597
e88404e8f2cf
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48925
diff
changeset
|
503 ;; A different help. Remove a previous tooltip, and |
35069
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
504 ;; display a new one, with some delay. |
25003 | 505 (tooltip-hide) |
35069
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
506 (tooltip-start-delayed-tip))))) |
25003 | 507 |
508 (defun tooltip-help-tips (event) | |
509 "Hook function to display a help tooltip. | |
35069
d19eadb47c76
(tooltip-cancel-delayed-tip)
Gerd Moellmann <gerd@gnu.org>
parents:
35044
diff
changeset
|
510 This is installed on the hook `tooltip-hook', which is run when |
42706 | 511 the timer with ID `tooltip-timeout-id' fires. |
25003 | 512 Value is non-nil if this function handled the tip." |
513 (when (stringp tooltip-help-message) | |
514 (tooltip-show tooltip-help-message) | |
515 t)) | |
516 | |
48601
ac47e19224b0
(tooltip-gud-process-output): Handle annotations that
Nick Roberts <nickrob@snap.net.nz>
parents:
48580
diff
changeset
|
517 (provide 'tooltip) |
25003 | 518 |
58155 | 519 ;; arch-tag: 3d61135e-4618-4a78-af28-183f6df5636f |
25003 | 520 ;;; tooltip.el ends here |