annotate lisp/term/bg-mouse.el @ 622:11502791fc1c

[xemacs-hg @ 2001-06-22 01:49:57 by ben] dired-msw.c: Fix problem noted by Michael Sperber with directories containing [] and code that destructively modifies an existing string. term\AT386.el: Fix warnings. term\apollo.el: Removed. Kill kill kill. Sync with FSF and remove most crap. term\linux.el: Removed. Sync with FSF. Don't define most defns, because they are automatically defined by termcap. But do add defns for keys that normally get defined as f13, f14, etc. and really ought to be shift-f3, shift-f4, etc. (NOTE: I did this based on Cygwin, which emulates the Linux console. I would appreciate it if someone on Linux could verify.) term\cygwin.el: New. Load term/linux. term\lk201.el, term\news.el, term\vt100.el: Sync with FSF. Fix warnings. dialog-gtk.el: Fix warning. For 21.4: help.el, update-elc.el: Compile in proper order. Maybe for 21.4: keydefs.el: Add a defn for M-?, previously undefined, to access help -- in case the terminal is not set up right, or f1 gets redefined. README: Rewrite.
author ben
date Fri, 22 Jun 2001 01:50:04 +0000
parents 1ccc32a20af4
children d682c0f82a71
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1 ;;; bg-mouse.el --- GNU Emacs code for BBN Bitgraph mouse.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3 ;; Copyright (C) Free Software Foundation, Inc. Oct 1985.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
4
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
5 ;; Author: John Robinson <jr@bbn-unix.arpa>
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
6 ;; Stephen Gildea <gildea@bbn.com>
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
7 ;; Maintainer: FSF
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
8 ;; Keywords: hardware
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
9
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
10 ;; This file is part of GNU Emacs.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
11
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
12 ;; GNU Emacs is free software; you can redistribute it and/or modify
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
13 ;; it under the terms of the GNU General Public License as published by
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
14 ;; the Free Software Foundation; either version 2, or (at your option)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
15 ;; any later version.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
16
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
17 ;; GNU Emacs is distributed in the hope that it will be useful,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
18 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
19 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
20 ;; GNU General Public License for more details.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
21
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
22 ;; You should have received a copy of the GNU General Public License
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
23 ;; along with GNU Emacs; see the file COPYING. If not, write to
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
24 ;; the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
25
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
26 ;;; Code:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
27
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
28 ;;; Original version by John Robinson (jr@bbn-unix.arpa, bbncca!jr), Oct 1985
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
29 ;;; Modularized and enhanced by gildea@bbn.com Nov 1987
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
30 ;;; Time stamp <89/03/21 14:27:08 gildea>
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
31
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
32 ;;; User customization option:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
33
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
34 (defvar bg-mouse-fast-select-window nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
35 "*Non-nil for mouse hits to select new window, then execute; else just select.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
36
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
37 ;;; These numbers are summed to make the index into the mouse-map.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
38 ;;; The low three bits correspond to what the mouse actually sends.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
39 (defconst bg-button-r 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
40 (defconst bg-button-m 2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
41 (defconst bg-button-c 2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
42 (defconst bg-button-l 4)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
43 (defconst bg-in-modeline 8)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
44 (defconst bg-in-scrollbar 16)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
45 (defconst bg-in-minibuf 24)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
46
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
47 ;;; semicolon screws up indenting, so use this instead
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
48 (defconst semicolon ?\;)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
49
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
50 ;;; Defuns:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
51
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
52 (defun bg-mouse-report (prefix-arg)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
53 "Read, parse, and execute a BBN BitGraph mouse click.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
54
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
55 L-- move point | These apply for mouse click in a window.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
56 --R set mark | If bg-mouse-fast-select-window is nil,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
57 L-R kill region | these commands on a nonselected window
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
58 -C- move point and yank | just select that window.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
59 LC- yank-pop |
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
60 -CR or LCR undo | \"Scroll bar\" is right-hand window column.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
61
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
62 on modeline: on \"scroll bar\": in minibuffer:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
63 L-- scroll-up line to top execute-extended-command
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
64 --R scroll-down line to bottom eval-expression
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
65 -C- proportional goto-char line to middle suspend-emacs
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
66
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
67 To reinitialize the mouse if the terminal is reset, type ESC : RET"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
68 (interactive "P")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
69 (bg-get-tty-num semicolon)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
70 (let*
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
71 ((screen-mouse-x (min (1- (frame-width)) ;don't hit column 86!
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
72 (/ (bg-get-tty-num semicolon) 9)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
73 (screen-mouse-y (- (1- (frame-height)) ;assume default font size.
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 0
diff changeset
74 (/ (bg-get-tty-num semicolon) 16)))
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
75 (bg-mouse-buttons (% (bg-get-tty-num ?c) 8))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
76 (bg-mouse-window (bg-window-from-x-y screen-mouse-x screen-mouse-y))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
77 (bg-cursor-window (selected-window))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
78 (edges (window-edges bg-mouse-window))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
79 (minibuf-p (= screen-mouse-y (1- (screen-height))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
80 (in-modeline-p (and (not minibuf-p)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
81 (= screen-mouse-y (1- (nth 3 edges)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
82 (in-scrollbar-p (and (not minibuf-p) (not in-modeline-p)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
83 (>= screen-mouse-x (1- (nth 2 edges)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
84 (same-window-p (eq bg-mouse-window bg-cursor-window))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
85 (in-minibuf-p (and minibuf-p
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
86 (not bg-mouse-window))) ;minibuf must be inactive
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
87 (bg-mode-bits (+ (if in-minibuf-p bg-in-minibuf 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
88 (if in-modeline-p bg-in-modeline 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
89 (if in-scrollbar-p bg-in-scrollbar 0)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
90 (bg-command
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
91 (lookup-key mouse-map
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
92 (char-to-string (+ bg-mode-bits bg-mouse-buttons))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
93 (bg-mouse-x (- screen-mouse-x (nth 0 edges)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
94 (bg-mouse-y (- screen-mouse-y (nth 1 edges))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
95 (cond ((or in-modeline-p in-scrollbar-p)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
96 (select-window bg-mouse-window)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
97 (bg-command-execute bg-command)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
98 (select-window bg-cursor-window))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
99 ((or same-window-p in-minibuf-p)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
100 (bg-command-execute bg-command))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
101 (t ;in another window
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
102 (select-window bg-mouse-window)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
103 (if bg-mouse-fast-select-window
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
104 (bg-command-execute bg-command)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
105 )))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
106
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
107
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
108 ;;; Library of commands:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
109
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
110 (defun bg-set-point ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
111 "Move point to location of BitGraph mouse."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
112 (interactive)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
113 (bg-move-point-to-x-y bg-mouse-x bg-mouse-y)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
114 (setq this-command 'next-line) ;make subsequent line moves work
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
115 (setq temporary-goal-column bg-mouse-x))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
116
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
117 (defun bg-set-mark ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
118 "Set mark at location of BitGraph mouse."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
119 (interactive)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
120 (push-mark)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
121 (bg-move-point-to-x-y bg-mouse-x bg-mouse-y)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
122 (exchange-point-and-mark))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
123
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
124 (defun bg-yank ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
125 "Move point to location of BitGraph mouse and yank."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
126 (interactive "*")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
127 (bg-move-point-to-x-y bg-mouse-x bg-mouse-y)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
128 (setq this-command 'yank)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
129 (yank))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
130
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
131 (defun yank-pop-1 ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
132 (interactive "*")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
133 (yank-pop 1))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
134
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
135 (defun bg-yank-or-pop ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
136 "Move point to location of BitGraph mouse and yank. If last command
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
137 was a yank, do a yank-pop."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
138 (interactive "*")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
139 (if (eql last-command 'yank)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
140 (yank-pop 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
141 (bg-yank)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
142
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
143 ;;; In 18.51, Emacs Lisp doesn't provide most-positive-fixnum
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
144 (defconst bg-most-positive-fixnum 8388607)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
145
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
146 (defun bg-move-by-percentage ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
147 "Go to location in buffer that is the same percentage of the way
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
148 through the buffer as the BitGraph mouse's X position in the window."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
149 (interactive)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
150 ;; check carefully for overflow in intermediate calculations
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
151 (goto-char
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
152 (cond ((zerop bg-mouse-x)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
153 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
154 ((< (buffer-size) (/ bg-most-positive-fixnum bg-mouse-x))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
155 ;; no danger of overflow: compute it exactly
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
156 (/ (* bg-mouse-x (buffer-size))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
157 (1- (window-width))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
158 (t
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
159 ;; overflow possible: approximate
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
160 (* (/ (buffer-size) (1- (window-width)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
161 bg-mouse-x))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
162 (beginning-of-line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
163 (what-cursor-position))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
164
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
165 (defun bg-mouse-line-to-top ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
166 "Scroll the line pointed to by the BitGraph mouse to the top of the window."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
167 (interactive)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
168 (scroll-up bg-mouse-y))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
169
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
170 (defun bg-mouse-line-to-center ()
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 0
diff changeset
171 "Scroll the line pointed to by the BitGraph mouse to the center
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 0
diff changeset
172 of the window."
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
173 (interactive)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
174 (scroll-up (/ (+ 2 bg-mouse-y bg-mouse-y (- (window-height))) 2)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
175
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
176 (defun bg-mouse-line-to-bottom ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
177 "Scroll the line pointed to by the mouse to the bottom of the window."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
178 (interactive)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
179 (scroll-up (+ bg-mouse-y (- 2 (window-height)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
180
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
181 (defun bg-kill-region ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
182 (interactive "*")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
183 (kill-region (region-beginning) (region-end)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
184
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
185 (defun bg-insert-moused-sexp ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
186 "Insert a copy of the word (actually sexp) that the mouse is pointing at.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
187 Sexp is inserted into the buffer at point (where the text cursor is)."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
188 (interactive)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
189 (let ((moused-text
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
190 (save-excursion
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
191 (bg-move-point-to-x-y bg-mouse-x bg-mouse-y)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
192 (if (looking-at "\\s)")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
193 (forward-char 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
194 (forward-sexp 1))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
195 (buffer-substring (save-excursion (backward-sexp 1) (point))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
196 (point)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
197 (select-window bg-cursor-window)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
198 (delete-horizontal-space)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
199 (cond
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
200 ((bolp)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
201 (indent-according-to-mode))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
202 ;; In Lisp assume double-quote is closing; in Text assume opening.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
203 ;; Why? Because it does the right thing most often.
446
1ccc32a20af4 Import from CVS: tag r21-2-38
cvs
parents: 444
diff changeset
204 ((save-excursion (backward-char 1)
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
205 (and (not (looking-at "\\s\""))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
206 (looking-at "[`'\"\\]\\|\\s(")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
207 nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
208 (t
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
209 (insert-string " ")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
210 (insert-string moused-text)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
211 (or (eolp)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
212 (looking-at "\\s.\\|\\s)")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
213 (and (looking-at "'") (looking-at "\\sw")) ;hack for text mode
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
214 (save-excursion (insert-string " ")))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
215
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
216 ;;; Utility functions:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
217
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
218 (defun bg-get-tty-num (term-char)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
219 "Read from terminal until TERM-CHAR is read, and return intervening number.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
220 If non-numeric not matching TERM-CHAR, reprogram the mouse and signal an error."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
221 (let
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
222 ((num 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
223 (char (- (read-char) 48)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
224 (while (and (>= char 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
225 (<= char 9))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
226 (setq num (+ (* num 10) char))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
227 (setq char (- (read-char) 48)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
228 (or (eq term-char (+ char 48))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
229 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
230 (bg-program-mouse)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
231 (error
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
232 "Invalid data format in bg-mouse command: mouse reinitialized.")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
233 num))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
234
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
235 ;;; Note that this fails in the minibuf because move-to-column doesn't
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
236 ;;; allow for the width of the prompt.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
237 (defun bg-move-point-to-x-y (x y)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
238 "Position cursor in window coordinates.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
239 X and Y are 0-based character positions in the window."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
240 (move-to-window-line y)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
241 ;; if not on a wrapped line, zero-column will be 0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
242 (let ((zero-column (current-column))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
243 (scroll-offset (window-hscroll)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
244 ;; scrolling takes up column 0 to display the $
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
245 (if (> scroll-offset 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
246 (setq scroll-offset (1- scroll-offset)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
247 (move-to-column (+ zero-column scroll-offset x))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
248 ))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
249
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
250 ;;; Returns the window that screen position (x, y) is in or nil if none,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
251 ;;; meaning we are in the echo area with a non-active minibuffer.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
252 ;;; If coordinates-in-window-p were not in an X-windows-specific file
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
253 ;;; we could use that. In Emacs 19 can even use locate-window-from-coordinates
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
254 (defun bg-window-from-x-y (x y)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
255 "Find window corresponding to screen coordinates.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
256 X and Y are 0-based character positions on the screen."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
257 (let ((edges (window-edges))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
258 (window nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
259 (while (and (not (eq window (selected-window)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
260 (or (< y (nth 1 edges))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
261 (>= y (nth 3 edges))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
262 (< x (nth 0 edges))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
263 (>= x (nth 2 edges))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
264 (setq window (next-window window))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
265 (setq edges (window-edges window)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
266 (cond ((eq window (selected-window))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
267 nil) ;we've looped: not found
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
268 ((not window)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
269 (selected-window)) ;just starting: current window
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
270 (t
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
271 window))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
272 ))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
273
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
274 (defun bg-command-execute (bg-command)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
275 (if (commandp bg-command)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
276 (command-execute bg-command)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
277 (ding)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
278
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
279 (defun bg-program-mouse ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
280 (send-string-to-terminal "\e:0;7;;;360;512;9;16;9;16c"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
281
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
282 ;;; Note that the doc string for mouse-map (as defined in subr.el)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
283 ;;; says it is for the X-window mouse. This is wrong; that keymap
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
284 ;;; should be used for your mouse no matter what terminal you have.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
285
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
286 (or (keymapp mouse-map)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
287 (setq mouse-map (make-keymap)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
288
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
289 (defun bind-bg-mouse-click (click-code function)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
290 "Bind bg-mouse CLICK-CODE to run FUNCTION."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
291 (define-key mouse-map (char-to-string click-code) function))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
292
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 0
diff changeset
293 (bind-bg-mouse-click bg-button-l 'bg-set-point)
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
294 (bind-bg-mouse-click bg-button-m 'bg-yank)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
295 (bind-bg-mouse-click bg-button-r 'bg-set-mark)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
296 (bind-bg-mouse-click (+ bg-button-l bg-button-m) 'yank-pop-1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
297 (bind-bg-mouse-click (+ bg-button-l bg-button-r) 'bg-kill-region)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
298 (bind-bg-mouse-click (+ bg-button-m bg-button-r) 'undo)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
299 (bind-bg-mouse-click (+ bg-button-l bg-button-m bg-button-r) 'undo)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
300 (bind-bg-mouse-click (+ bg-in-modeline bg-button-l) 'scroll-up)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
301 (bind-bg-mouse-click (+ bg-in-modeline bg-button-m) 'bg-move-by-percentage)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
302 (bind-bg-mouse-click (+ bg-in-modeline bg-button-r) 'scroll-down)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
303 (bind-bg-mouse-click (+ bg-in-scrollbar bg-button-l) 'bg-mouse-line-to-top)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
304 (bind-bg-mouse-click (+ bg-in-scrollbar bg-button-m) 'bg-mouse-line-to-center)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
305 (bind-bg-mouse-click (+ bg-in-scrollbar bg-button-r) 'bg-mouse-line-to-bottom)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
306 (bind-bg-mouse-click (+ bg-in-minibuf bg-button-l) 'execute-extended-command)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
307 (bind-bg-mouse-click (+ bg-in-minibuf bg-button-m) 'suspend-emacs)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
308 (bind-bg-mouse-click (+ bg-in-minibuf bg-button-r) 'eval-expression)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
309
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
310 (provide 'bg-mouse)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
311
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
312 ;;; bg-mouse.el ends here