Mercurial > emacs
annotate lisp/emulation/edt.el @ 923:9f3cc03dae67
entered into RCS
author | Jim Blandy <jimb@redhat.com> |
---|---|
date | Tue, 04 Aug 1992 04:15:43 +0000 |
parents | 20674ae6bf52 |
children | a880046a1a67 |
rev | line source |
---|---|
660
08eb386dd0f3
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
258
diff
changeset
|
1 ;;; edt.el --- EDT emulation in Emacs |
08eb386dd0f3
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
258
diff
changeset
|
2 |
846
20674ae6bf52
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
811
diff
changeset
|
3 ;; Copyright (C) 1986 Free Software Foundation, Inc. |
20674ae6bf52
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
811
diff
changeset
|
4 |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
793
diff
changeset
|
5 ;; Author: Mike Clarkson <mike@yetti.UUCP> |
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
793
diff
changeset
|
6 ;; Maintainer: FSF |
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
793
diff
changeset
|
7 ;; Created: 27 Aug 1986 |
811
e694e0879463
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
807
diff
changeset
|
8 ;; Keywords: emulations |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
793
diff
changeset
|
9 |
846
20674ae6bf52
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
811
diff
changeset
|
10 ;; This started from public domain code by Mike Clarkson |
57 | 11 ;; but has been greatly altered. |
12 | |
13 ;; This file is part of GNU Emacs. | |
14 | |
15 ;; GNU Emacs is free software; you can redistribute it and/or modify | |
16 ;; it under the terms of the GNU General Public License as published by | |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
793
diff
changeset
|
17 ;; the Free Software Foundation; either version 2, or (at your option) |
57 | 18 ;; any later version. |
19 | |
20 ;; GNU Emacs is distributed in the hope that it will be useful, | |
21 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
22 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
23 ;; GNU General Public License for more details. | |
24 | |
25 ;; You should have received a copy of the GNU General Public License | |
26 ;; along with GNU Emacs; see the file COPYING. If not, write to | |
27 ;; the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. | |
28 | |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
793
diff
changeset
|
29 ;;; Commentary: |
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
793
diff
changeset
|
30 |
662
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
31 ;; Here's my EDT emulation for GNU Emacs that is based on the EDT emulation |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
32 ;; for Gosling's Emacs sent out on the net a couple of years ago by Lynn Olson |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
33 ;; at Tektronics. This emulation was widely distributed as the file edt.ml |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
34 ;; in the maclib directory of most Emacs distributions. |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
35 ;; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
36 ;; I will gladly take all criticisms and complaints to heart, and will fix what |
793
6fb68a1460a6
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
662
diff
changeset
|
37 ;; bugs I can find. As this is my first Emacs Lisp hack, you may have to root |
6fb68a1460a6
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
662
diff
changeset
|
38 ;; out a few nasties hidden in the code. Please let me know if you find any |
6fb68a1460a6
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
662
diff
changeset
|
39 ;; (sorry, no rewards :-). I would also be interested if there are better, |
6fb68a1460a6
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
662
diff
changeset
|
40 ;; cleaner, faster ways of doing some of the things that I have done. |
662
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
41 ;; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
42 ;; You must understand some design considerations that I had in mind. |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
43 ;; The intention was not really to "emulate" EDT, but rather to take advantage |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
44 ;; of the years of EDT experience that had accumulated in my right hand, |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
45 ;; while at the same time taking advantage of EMACS. |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
46 ;; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
47 ;; Some major differences are: |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
48 ;; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
49 ;; HELP is describe-key; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
50 ;; GOLD/HELP is describe-function; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
51 ;; FIND is isearch-forward/backward; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
52 ;; GOLD/HELP is occur-menu, which finds all instances of a search string; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
53 ;; ENTER is other-window; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
54 ;; SUBS is subprocess-command. Note that you have to change this |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
55 ;; to `shell' if you are running Un*x; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
56 ;; PAGE is next-paragraph, because that's more useful than page. |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
57 ;; SPECINS is copy-to-killring; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
58 ;; GOLD/GOLD is mark-section-wisely, which is my command to mark the |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
59 ;; section in a manner consistent with the major-mode. It |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
60 ;; uses mark-defun for emacs-lisp, lisp, mark-c-function for C, |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
61 ;; and mark-paragraph for other modes. |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
62 ;; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
63 ;; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
64 ;; Some subtle differences are: |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
65 ;; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
66 ;; APPEND is append-to-buffer. One doesn't append to the kill ring |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
67 ;; much and SPECINS is now copy-to-killring; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
68 ;; REPLACE is replace-regexp; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
69 ;; FILL is fill-region-wisely, which uses indent-region for C, lisp |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
70 ;; emacs-lisp, and fill-region for others. It asks if you |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
71 ;; really want to fill-region in TeX-mode, because I find this |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
72 ;; to be very dangerous. |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
73 ;; CHNGCASE is case-flip for the character under the cursor only. |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
74 ;; I felt that case-flip region is unlikely, as usually you |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
75 ;; upcase-region or downcase region. Also, unlike EDT it |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
76 ;; is independent of the direction you are going, as that |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
77 ;; drives me nuts. |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
78 ;; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
79 ;; I use Emacs definition of what a word is. This is considerably different |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
80 ;; from what EDT thinks a word is. This is not good for dyed-in-the-wool EDT |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
81 ;; fans, but is probably preferable for experienced Emacs users. My assumption |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
82 ;; is that the former are a dying breed now that GNU Emacs has made it to VMS, |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
83 ;; but let me know how you feel. Also, when you undelete a word it leave the |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
84 ;; point at the end of the undeleted text, rather than the beginning. I might |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
85 ;; change this as I'm not sure if I like this or not. I'm also not sure if I |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
86 ;; want it to set the mark each time you delete a character or word. |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
87 ;; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
88 ;; Backspace does not invoke beginning-of-line, because ^H is the help prefix, |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
89 ;; and I felt it should be left as such. You can change this if you like. |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
90 ;; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
91 ;; The ADVANCE and BACKUP keys do not work as terminators for forward or |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
92 ;; backward searches. In Emacs, all search strings are terminated by return. |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
93 ;; The searches will however go forward or backward depending on your current |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
94 ;; direction. Also, when you change directions, the mode line will not be |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
95 ;; updated immediately, but only when you next execute an emacs function. |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
96 ;; Personally, I consider this to be a bug, not a feature. |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
97 ;; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
98 ;; This should also work with VT-2xx's, though I haven't tested it extensively |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
99 ;; on those terminals. It assumes that the CSI-map of vt_200.el has been |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
100 ;; defined. |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
101 ;; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
102 ;; There are also a whole bunch of GOLD letter, and GOLD character bindings: |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
103 ;; look at edtdoc.el for them, or better still, look at the edt.el lisp code, |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
104 ;; because after all, in the true Lisp tradition, the source code is *assumed* |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
105 ;; to be self-documenting :-) |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
106 ;; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
107 ;; Mike Clarkson, ...!allegra \ BITNET: mike@YUYETTI or |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
108 ;; CRESS, York University, ...!decvax \ SYMALG@YUSOL |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
109 ;; 4700 Keele Street, ...!ihnp4 > !utzoo!yetti!mike |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
110 ;; North York, Ontario, ...!linus / |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
111 ;; CANADA M3J 1P3. ...!watmath / Phone: +1 (416) 736-2100 x 7767 |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
112 ;; |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
113 ;; Note that I am not on ARPA, and must gateway any ARPA mail through BITNET or |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
114 ;; UUCP. If you have a UUCP or BITNET address please use it for communication |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
115 ;; so that I can reach you directly. If you have both, the BITNET address |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
116 ;; is preferred. |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
793
diff
changeset
|
117 |
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
793
diff
changeset
|
118 ;;; Code: |
662
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
660
diff
changeset
|
119 |
57 | 120 (defvar edt-last-deleted-lines "" |
199 | 121 "Last text deleted by an EDT emulation `line-delete' command.") |
57 | 122 (defvar edt-last-deleted-words "" |
199 | 123 "Last text deleted by an EDT emulation `word-delete' command.") |
57 | 124 (defvar edt-last-deleted-chars "" |
199 | 125 "Last text deleted by an EDT emulation `character-delete' command.") |
57 | 126 |
127 (defun delete-current-line (num) | |
128 "Delete one or specified number of lines after point. | |
129 This includes the newline character at the end of each line. | |
199 | 130 They are saved for the EDT `undelete-lines' command." |
57 | 131 (interactive "p") |
132 (let ((beg (point))) | |
133 (forward-line num) | |
134 (if (not (eq (preceding-char) ?\n)) | |
135 (insert "\n")) | |
136 (setq edt-last-deleted-lines | |
137 (buffer-substring beg (point))) | |
138 (delete-region beg (point)))) | |
139 | |
140 (defun delete-to-eol (num) | |
141 "Delete text up to end of line. | |
142 With argument, delete up to to Nth line-end past point. | |
199 | 143 They are saved for the EDT `undelete-lines' command." |
57 | 144 (interactive "p") |
145 (let ((beg (point))) | |
146 (forward-char 1) | |
147 (end-of-line num) | |
148 (setq edt-last-deleted-lines | |
149 (buffer-substring beg (point))) | |
150 (delete-region beg (point)))) | |
151 | |
152 (defun delete-current-word (num) | |
153 "Delete one or specified number of words after point. | |
199 | 154 They are saved for the EDT `undelete-words' command." |
57 | 155 (interactive "p") |
156 (let ((beg (point))) | |
157 (forward-word num) | |
158 (setq edt-last-deleted-words | |
159 (buffer-substring beg (point))) | |
160 (delete-region beg (point)))) | |
161 | |
162 (defun edt-delete-previous-word (num) | |
163 "Delete one or specified number of words before point. | |
199 | 164 They are saved for the EDT `undelete-words' command." |
57 | 165 (interactive "p") |
166 (let ((beg (point))) | |
167 (forward-word (- num)) | |
168 (setq edt-last-deleted-words | |
169 (buffer-substring (point) beg)) | |
170 (delete-region beg (point)))) | |
171 | |
172 (defun delete-current-char (num) | |
173 "Delete one or specified number of characters after point. | |
199 | 174 They are saved for the EDT `undelete-chars' command." |
57 | 175 (interactive "p") |
176 (setq edt-last-deleted-chars | |
177 (buffer-substring (point) (min (point-max) (+ (point) num)))) | |
178 (delete-region (point) (min (point-max) (+ (point) num)))) | |
179 | |
180 (defun delete-previous-char (num) | |
181 "Delete one or specified number of characters before point. | |
199 | 182 They are saved for the EDT `undelete-chars' command." |
57 | 183 (interactive "p") |
184 (setq edt-last-deleted-chars | |
185 (buffer-substring (max (point-min) (- (point) num)) (point))) | |
186 (delete-region (max (point-min) (- (point) num)) (point))) | |
187 | |
188 (defun undelete-lines () | |
199 | 189 "Yank lines deleted by last EDT `line-delete' command." |
57 | 190 (interactive) |
191 (insert edt-last-deleted-lines)) | |
192 | |
193 (defun undelete-words () | |
199 | 194 "Yank words deleted by last EDT `word-delete' command." |
57 | 195 (interactive) |
196 (insert edt-last-deleted-words)) | |
197 | |
198 (defun undelete-chars () | |
199 | 199 "Yank characters deleted by last EDT `character-delete' command." |
57 | 200 (interactive) |
201 (insert edt-last-deleted-chars)) | |
202 | |
203 (defun next-end-of-line (num) | |
204 "Move to end of line; if at end, move to end of next line. | |
205 Accepts a prefix argument for the number of lines to move." | |
206 (interactive "p") | |
207 (forward-char) | |
208 (end-of-line num)) | |
209 | |
210 (defun previous-end-of-line (num) | |
211 "Move EOL upward. | |
212 Accepts a prefix argument for the number of lines to move." | |
213 (interactive "p") | |
214 (end-of-line (- 1 num))) | |
215 | |
216 (defun forward-to-word (num) | |
217 "Move to next word-beginning, or to Nth following word-beginning." | |
218 (interactive "p") | |
219 (forward-word (1+ num)) | |
220 (forward-word -1)) | |
221 | |
222 (defun backward-to-word (num) | |
223 "Move back to word-end, or to Nth word-end seen." | |
224 (interactive "p") | |
225 (forward-word (- (1+ num))) | |
226 (forward-word 1)) | |
227 | |
228 (defun backward-line (num) | |
229 "Move point to start of previous line. | |
230 Prefix argument serves as repeat-count." | |
231 (interactive "p") | |
232 (forward-line (- num))) | |
233 | |
234 (defun scroll-window-down (num) | |
235 "Scroll the display down a window-full. | |
236 Accepts a prefix argument for the number of window-fulls to scroll." | |
237 (interactive "p") | |
238 (scroll-down (- (* (window-height) num) 2))) | |
239 | |
240 (defun scroll-window-up (num) | |
241 "Scroll the display up a window-full. | |
242 Accepts a prefix argument for the number of window-fulls to scroll." | |
243 (interactive "p") | |
244 (scroll-up (- (* (window-height) num) 2))) | |
245 | |
246 (defun next-paragraph (num) | |
247 "Move to beginning of the next indented paragraph. | |
248 Accepts a prefix argument for the number of paragraphs." | |
249 (interactive "p") | |
250 (while (> num 0) | |
251 (next-line 1) | |
252 (forward-paragraph) | |
253 (previous-line 1) | |
254 (if (eolp) (next-line 1)) | |
255 (setq num (1- num)))) | |
256 | |
257 (defun previous-paragraph (num) | |
258 "Move to beginning of previous indented paragraph. | |
259 Accepts a prefix argument for the number of paragraphs." | |
260 (interactive "p") | |
261 (while (> num 0) | |
262 (backward-paragraph) | |
263 (previous-line 1) | |
264 (if (eolp) (next-line 1)) | |
265 (setq num (1- num)))) | |
266 | |
267 (defun move-to-beginning () | |
268 "Move cursor to the beginning of buffer, but don't set the mark." | |
269 (interactive) | |
270 (goto-char (point-min))) | |
271 | |
272 (defun move-to-end () | |
273 "Move cursor to the end of buffer, but don't set the mark." | |
274 (interactive) | |
275 (goto-char (point-max))) | |
276 | |
277 (defun goto-percent (perc) | |
278 "Move point to ARG percentage of the buffer." | |
279 (interactive "NGoto-percentage: ") | |
280 (if (or (> perc 100) (< perc 0)) | |
281 (error "Percentage %d out of range 0 < percent < 100" perc) | |
282 (goto-char (/ (* (point-max) perc) 100)))) | |
283 | |
284 (defun update-mode-line () | |
199 | 285 "Ensure mode-line reflects all changes." |
57 | 286 (set-buffer-modified-p (buffer-modified-p)) |
287 (sit-for 0)) | |
288 | |
289 (defun advance-direction () | |
290 "Set EDT Advance mode so keypad commands move forward." | |
291 (interactive) | |
292 (setq edt-direction-string " ADVANCE") | |
923 | 293 (global-set-key [kp-f1] 'isearch-forward) |
294 (global-set-key [kp-8] 'scroll-window-up) | |
295 (global-set-key [kp-7] 'next-paragraph) | |
296 (global-set-key [kp-1] 'forward-to-word) | |
297 (global-set-key [kp-2] 'next-end-of-line) | |
298 (global-set-key [kp-3] 'forward-char) | |
299 (global-set-key [kp-0] 'forward-line) | |
57 | 300 (update-mode-line)) |
301 | |
302 (defun backup-direction () | |
303 "Set EDT Backup mode so keypad commands move backward." | |
304 (interactive) | |
305 (setq edt-direction-string " BACKUP") | |
923 | 306 (global-set-key [kp-f3] 'isearch-backward) |
307 (global-set-key [kp-8] 'scroll-window-down) | |
308 (global-set-key [kp-7] 'previous-paragraph) | |
309 (global-set-key [kp-1] 'backward-to-word) | |
310 (global-set-key [kp-2] 'previous-end-of-line) | |
311 (global-set-key [kp-3] 'backward-char) | |
312 (global-set-key [kp-9] 'backward-line) | |
57 | 313 (update-mode-line)) |
314 | |
315 (defun edt-beginning-of-window () | |
316 "Home cursor to top of window." | |
317 (interactive) | |
318 (move-to-window-line 0)) | |
319 | |
320 (defun edt-line-to-bottom-of-window () | |
321 "Move the current line to the top of the window." | |
322 (interactive) | |
323 (recenter -1)) | |
324 | |
325 (defun edt-line-to-top-of-window () | |
326 "Move the current line to the top of the window." | |
327 (interactive) | |
328 (recenter 0)) | |
329 | |
330 (defun case-flip-character (num) | |
331 "Change the case of the character under the cursor. | |
332 Accepts a prefix argument of the number of characters to invert." | |
333 (interactive "p") | |
334 (while (> num 0) | |
335 (funcall (if (<= ?a (following-char)) | |
336 'upcase-region 'downcase-region) | |
337 (point) (1+ (point))) | |
338 (forward-char 1) | |
339 (setq num (1- num)))) | |
340 | |
341 (defun indent-or-fill-region () | |
342 "Fill region in text modes, indent region in programming language modes." | |
343 (interactive) | |
344 (if (string= paragraph-start "^$\\|^") | |
345 (indent-region (point) (mark) nil) | |
346 (fill-region (point) (mark)))) | |
347 | |
348 (defun mark-section-wisely () | |
349 "Mark the section in a manner consistent with the major-mode. | |
350 Uses mark-defun for emacs-lisp, lisp, | |
351 mark-c-function for C, | |
352 and mark-paragraph for other modes." | |
353 (interactive) | |
354 (cond ((eq major-mode 'emacs-lisp-mode) | |
355 (mark-defun)) | |
356 ((eq major-mode 'lisp-mode) | |
357 (mark-defun)) | |
358 ((eq major-mode 'c-mode) | |
359 (mark-c-function)) | |
360 (t (mark-paragraph)))) | |
361 | |
362 ;;; Key Bindings | |
258 | 363 ;;;###autoload |
57 | 364 (defun edt-emulation-on () |
199 | 365 "Emulate DEC's EDT editor. |
366 Note that many keys are rebound; including nearly all keypad keys. | |
923 | 367 Use \\[edt-emulation-off] to undo all rebindings except the keypad keys." |
57 | 368 (interactive) |
369 (advance-direction) | |
923 | 370 (edt-bind-gold-keypad) |
57 | 371 (setq edt-mode-old-c-\\ (lookup-key global-map "\C-\\")) |
372 (global-set-key "\C-\\" 'quoted-insert) | |
373 (setq edt-mode-old-delete (lookup-key global-map "\177")) | |
374 (global-set-key "\177" 'delete-previous-char) ;"Delete" | |
375 (setq edt-mode-old-lisp-delete (lookup-key emacs-lisp-mode-map "\177")) | |
376 (define-key emacs-lisp-mode-map "\177" 'delete-previous-char) ;"Delete" | |
377 (define-key lisp-mode-map "\177" 'delete-previous-char) ;"Delete" | |
378 (setq edt-mode-old-linefeed (lookup-key global-map "\C-j")) | |
379 (global-set-key "\C-j" 'edt-delete-previous-word) ;"LineFeed" | |
380 (define-key esc-map "?" 'apropos)) ;"<ESC>?" | |
381 | |
382 (defun edt-emulation-off () | |
383 "Return from EDT emulation to normal Emacs key bindings. | |
384 The keys redefined by \\[edt-emulation-on] are given their old definitions." | |
385 (interactive) | |
386 (setq edt-direction-string nil) | |
387 (global-set-key "\C-\\" edt-mode-old-c-\\) | |
388 (global-set-key "\177" edt-mode-old-delete) ;"Delete" | |
389 (define-key emacs-lisp-mode-map "\177" edt-mode-old-lisp-delete) ;"Delete" | |
390 (define-key lisp-mode-map "\177" edt-mode-old-lisp-delete) ;"Delete" | |
391 (global-set-key "\C-j" edt-mode-old-linefeed)) ;"LineFeed" | |
392 | |
393 (fset 'GOLD-prefix GOLD-map) | |
394 | |
395 (defvar GOLD-map (make-keymap) | |
199 | 396 "`GOLD-map' maps the function keys on the VT100 keyboard preceeded |
57 | 397 by the PF1 key. GOLD is the ASCII the 7-bit escape sequence <ESC>OP.") |
398 | |
923 | 399 (global-set-key [home] 'edt-beginning-of-window) |
400 (global-set-key [kp-f2] 'describe-key) | |
401 (global-set-key [kp-f4] 'delete-current-line) | |
402 (global-set-key [kp-9] 'append-to-buffer) | |
403 (global-set-key [kp-subtract] 'delete-current-word) | |
404 (global-set-key [kp-4] 'advance-direction) | |
405 (global-set-key [kp-5] 'backup-direction) | |
406 (global-set-key [kp-6] 'kill-region) | |
407 (global-set-key [kp-separator] 'delete-current-char) | |
408 (global-set-key [kp-decimal] 'set-mark-command) | |
409 (global-set-key [kp-enter] 'other-window) | |
410 (global-set-key [kp-f1] 'GOLD-prefix) | |
57 | 411 |
412 ;;Bind GOLD/Keyboard keys | |
413 | |
414 (define-key GOLD-map "\C-g" 'keyboard-quit) ; just for safety | |
415 (define-key GOLD-map "\177" 'delete-window) ;"Delete" | |
416 (define-key GOLD-map "\C-h" 'delete-other-windows) ;"BackSpace" | |
417 (define-key GOLD-map "\C-m" 'newline-and-indent) ;"Return" | |
418 (define-key GOLD-map " " 'undo) ;"Spacebar" | |
419 (define-key GOLD-map "%" 'goto-percent) ; "%" | |
420 (define-key GOLD-map "=" 'goto-line) ; "=" | |
421 (define-key GOLD-map "`" 'what-line) ; "`" | |
422 (define-key GOLD-map "\C-\\" 'split-window-vertically) ; "Control-\" | |
423 | |
424 ; GOLD letter combinations: | |
425 (define-key GOLD-map "b" 'buffer-menu) ; "b" | |
426 (define-key GOLD-map "B" 'buffer-menu) ; "B" | |
427 (define-key GOLD-map "d" 'delete-window) ; "d" | |
428 (define-key GOLD-map "D" 'delete-window) ; "D" | |
429 (define-key GOLD-map "e" 'compile) ; "e" | |
430 (define-key GOLD-map "E" 'compile) ; "E" | |
431 (define-key GOLD-map "i" 'insert-file) ; "i" | |
432 (define-key GOLD-map "I" 'insert-file) ; "I" | |
433 (define-key GOLD-map "l" 'goto-line) ; "l" | |
434 (define-key GOLD-map "L" 'goto-line) ; "L" | |
435 (define-key GOLD-map "m" 'save-some-buffers) ; "m" | |
436 (define-key GOLD-map "M" 'save-some-buffers) ; "m" | |
437 (define-key GOLD-map "n" 'next-error) ; "n" | |
438 (define-key GOLD-map "N" 'next-error) ; "N" | |
439 (define-key GOLD-map "o" 'switch-to-buffer-other-window) ; "o" | |
440 (define-key GOLD-map "O" 'switch-to-buffer-other-window) ; "O" | |
441 (define-key GOLD-map "r" 'revert-file) ; "r" | |
442 (define-key GOLD-map "r" 'revert-file) ; "R" | |
443 (define-key GOLD-map "s" 'save-buffer) ; "s" | |
444 (define-key GOLD-map "S" 'save-buffer) ; "S" | |
445 (define-key GOLD-map "v" 'find-file-other-window) ; "v" | |
446 (define-key GOLD-map "V" 'find-file-other-window) ; "V" | |
447 (define-key GOLD-map "w" 'write-file) ; "w" | |
448 (define-key GOLD-map "w" 'write-file) ; "W" | |
449 ;(define-key GOLD-map "z" 'shrink-window) ; "z" | |
450 ;(define-key GOLD-map "Z" 'shrink-window) ; "z" | |
451 | |
452 ;Bind GOLD/Keypad keys | |
453 (defun edt-bind-gold-keypad () | |
923 | 454 (define-key GOLD-map [up] 'edt-line-to-top-of-window) |
455 (define-key GOLD-map [down] 'edt-line-to-bottom-of-window) | |
456 (define-key GOLD-map [left] 'backward-sentence) | |
457 (define-key GOLD-map [right] 'forward-sentence) | |
458 (define-key GOLD-map [kp-f1] 'mark-section-wisely) | |
459 (define-key GOLD-map [kp-f2] 'describe-function) | |
460 (define-key GOLD-map [kp-f3] 'occur) | |
461 (define-key GOLD-map [kp-f4] 'undelete-lines) | |
462 (define-key GOLD-map [kp-0] 'open-line) | |
463 (define-key GOLD-map [kp-1] 'case-flip-character) | |
464 (define-key GOLD-map [kp-2] 'delete-to-eol) | |
465 (define-key GOLD-map [kp-3] 'copy-region-as-kill) | |
466 (define-key GOLD-map [kp-4] 'move-to-end) | |
467 (define-key GOLD-map [kp-5] 'move-to-beginning) | |
468 (define-key GOLD-map [kp-6] 'yank) | |
469 (define-key GOLD-map [kp-7] 'execute-extended-command) | |
470 (define-key GOLD-map [kp-8] 'indent-or-fill-region) | |
471 (define-key GOLD-map [kp-9] 'replace-regexp) | |
472 (define-key GOLD-map [kp-subtract] 'undelete-words) | |
473 (define-key GOLD-map [kp-separator] 'undelete-chars) | |
474 (define-key GOLD-map [kp-decimal] 'redraw-display) | |
475 (define-key GOLD-map [kp-enter] 'shell-command)) | |
57 | 476 |
477 ;; Make direction of motion show in mode line | |
478 ;; while EDT emulation is turned on. | |
479 ;; Note that the keypad is always turned on when in Emacs. | |
480 | |
481 (or (assq 'edt-direction-string minor-mode-alist) | |
482 (setq minor-mode-alist (cons '(edt-direction-string edt-direction-string) | |
483 minor-mode-alist))) | |
660
08eb386dd0f3
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
258
diff
changeset
|
484 |
08eb386dd0f3
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
258
diff
changeset
|
485 ;;; edt.el ends here |