Mercurial > emacs
annotate lisp/progmodes/tcl.el @ 11353:9e3da029f921
(x_window): Copy the frame name to non-Lisp string.
(defined_color): Fix typo (duplicate +).
(validate_x_resource_name): Change invalid chars to `_'.
author | Richard M. Stallman <rms@gnu.org> |
---|---|
date | Mon, 10 Apr 1995 07:55:29 +0000 |
parents | 7823947372f9 |
children | 635f5fb5d82a |
rev | line source |
---|---|
6710
85f4c4971597
Fixed up headers for release.
Tom Tromey <tromey@redhat.com>
parents:
6709
diff
changeset
|
1 ;; tcl.el --- Tcl code editing commands for Emacs |
6709 | 2 |
3 ;; Copyright (C) 1994 Free Software Foundation, Inc. | |
4 | |
6710
85f4c4971597
Fixed up headers for release.
Tom Tromey <tromey@redhat.com>
parents:
6709
diff
changeset
|
5 ;; Maintainer: Tom Tromey <tromey@busco.lanl.gov> |
85f4c4971597
Fixed up headers for release.
Tom Tromey <tromey@redhat.com>
parents:
6709
diff
changeset
|
6 ;; Author: Tom Tromey <tromey@busco.lanl.gov> |
85f4c4971597
Fixed up headers for release.
Tom Tromey <tromey@redhat.com>
parents:
6709
diff
changeset
|
7 ;; Chris Lindblad <cjl@lcs.mit.edu> |
85f4c4971597
Fixed up headers for release.
Tom Tromey <tromey@redhat.com>
parents:
6709
diff
changeset
|
8 ;; Keywords: languages tcl modes |
11303
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
9 ;; Version: $Revision: 1.27 $ |
6709 | 10 |
11 ;; This file is part of GNU Emacs. | |
12 | |
13 ;; GNU Emacs is free software; you can redistribute it and/or modify | |
14 ;; it under the terms of the GNU General Public License as published by | |
15 ;; the Free Software Foundation; either version 1, or (at your option) | |
16 ;; any later version. | |
17 | |
18 ;; GNU Emacs is distributed in the hope that it will be useful, | |
19 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
20 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
21 ;; GNU General Public License for more details. | |
22 | |
23 ;; You should have received a copy of the GNU General Public License | |
24 ;; along with GNU Emacs; see the file COPYING. If not, write to | |
25 ;; the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. | |
26 | |
27 ;; HOW TO INSTALL: | |
28 ;; Put the following forms in your .emacs to enable autoloading of Tcl | |
29 ;; mode, and auto-recognition of ".tcl" files. | |
30 ;; | |
31 ;; (autoload 'tcl-mode "tcl" "Tcl mode." t) | |
32 ;; (autoload 'inferior-tcl "tcl" "Run inferior Tcl process." t) | |
33 ;; (setq auto-mode-alist (append '(("\\.tcl$" . tcl-mode)) auto-mode-alist)) | |
34 ;; | |
35 ;; If you plan to use the interface to the TclX help files, you must | |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
36 ;; set the variable tcl-help-directory-list to point to the topmost |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
37 ;; directories containing the TclX help files. Eg: |
6709 | 38 ;; |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
39 ;; (setq tcl-help-directory-list '("/usr/local/lib/tclx/help")) |
6709 | 40 ;; |
41 ;; Also you will want to add the following to your .emacs: | |
42 ;; | |
43 ;; (autoload 'tcl-help-on-word "tcl" "Help on Tcl commands" t) | |
44 ;; | |
45 ;; FYI a *very* useful thing to do is nroff all the Tk man pages and | |
46 ;; put them in a subdir of the help system. | |
47 ;; | |
48 | |
49 ;;; Commentary: | |
50 | |
51 ;; LCD Archive Entry: | |
52 ;; tcl|Tom Tromey|tromey@busco.lanl.gov| | |
53 ;; Major mode for editing Tcl| | |
11303
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
54 ;; $Date: 1994/10/11 02:01:27 $|$Revision: 1.27 $|~/modes/tcl.el.Z| |
6709 | 55 |
56 ;; CUSTOMIZATION NOTES: | |
57 ;; * tcl-proc-list can be used to customize a list of things that | |
58 ;; "define" other things. Eg in my project I put "defvar" in this | |
59 ;; list. | |
60 ;; * tcl-typeword-list is similar, but uses font-lock-type-face. | |
61 ;; * tcl-keyword-list is a list of keywords. I've generally used this | |
62 ;; for flow-control words. Eg I add "unwind_protect" to this list. | |
63 ;; * tcl-type-alist can be used to minimally customize indentation | |
64 ;; according to context. | |
65 | |
66 ;; Change log: | |
7288 | 67 ;; $Log: tcl.el,v $ |
11303
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
68 ;; Revision 1.27 1994/10/11 02:01:27 tromey |
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
69 ;; (tcl-mode): imenu-create-index-function made buffer local. |
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
70 ;; |
9428
3d5070024b68
(tcl-mode): imenu-create-index-function made buffer local.
Tom Tromey <tromey@redhat.com>
parents:
8681
diff
changeset
|
71 ;; Revision 1.26 1994/09/01 18:06:24 tromey |
3d5070024b68
(tcl-mode): imenu-create-index-function made buffer local.
Tom Tromey <tromey@redhat.com>
parents:
8681
diff
changeset
|
72 ;; Added filename completion in inferior tcl mode |
3d5070024b68
(tcl-mode): imenu-create-index-function made buffer local.
Tom Tromey <tromey@redhat.com>
parents:
8681
diff
changeset
|
73 ;; |
8681
2fa333e36b60
Added filename completion in inferior tcl mode
Tom Tromey <tromey@redhat.com>
parents:
8581
diff
changeset
|
74 ;; Revision 1.25 1994/08/22 15:56:24 tromey |
2fa333e36b60
Added filename completion in inferior tcl mode
Tom Tromey <tromey@redhat.com>
parents:
8581
diff
changeset
|
75 ;; tcl-load-file default to current buffer. |
2fa333e36b60
Added filename completion in inferior tcl mode
Tom Tromey <tromey@redhat.com>
parents:
8581
diff
changeset
|
76 ;; |
8581
e7daed44da21
tcl-load-file default to current buffer.
Tom Tromey <tromey@redhat.com>
parents:
8580
diff
changeset
|
77 ;; Revision 1.24 1994/08/21 20:33:05 tromey |
e7daed44da21
tcl-load-file default to current buffer.
Tom Tromey <tromey@redhat.com>
parents:
8580
diff
changeset
|
78 ;; Fixed bug in tcl-guess-application. |
e7daed44da21
tcl-load-file default to current buffer.
Tom Tromey <tromey@redhat.com>
parents:
8580
diff
changeset
|
79 ;; |
8580
648f78c8ecf5
Fixed bug in tcl-guess-application.
Tom Tromey <tromey@redhat.com>
parents:
8575
diff
changeset
|
80 ;; Revision 1.23 1994/08/21 03:54:45 tromey |
648f78c8ecf5
Fixed bug in tcl-guess-application.
Tom Tromey <tromey@redhat.com>
parents:
8575
diff
changeset
|
81 ;; Keybindings don't overshadown comint bindings. |
648f78c8ecf5
Fixed bug in tcl-guess-application.
Tom Tromey <tromey@redhat.com>
parents:
8575
diff
changeset
|
82 ;; |
8575
2d50d249caf4
Keybindings don't overshadown comint bindings.
Tom Tromey <tromey@redhat.com>
parents:
8339
diff
changeset
|
83 ;; Revision 1.22 1994/07/26 00:46:07 tromey |
2d50d249caf4
Keybindings don't overshadown comint bindings.
Tom Tromey <tromey@redhat.com>
parents:
8339
diff
changeset
|
84 ;; Emacs 18 changes from Carl Witty. |
2d50d249caf4
Keybindings don't overshadown comint bindings.
Tom Tromey <tromey@redhat.com>
parents:
8339
diff
changeset
|
85 ;; |
8339
b6e4f16c969a
Emacs 18 changes from Carl Witty.
Tom Tromey <tromey@redhat.com>
parents:
8252
diff
changeset
|
86 ;; Revision 1.21 1994/07/14 22:49:21 tromey |
b6e4f16c969a
Emacs 18 changes from Carl Witty.
Tom Tromey <tromey@redhat.com>
parents:
8252
diff
changeset
|
87 ;; Added ";;;###autoload" comments where appropriate. |
b6e4f16c969a
Emacs 18 changes from Carl Witty.
Tom Tromey <tromey@redhat.com>
parents:
8252
diff
changeset
|
88 ;; |
8252
7d4674a34de3
Added ";;;###autoload" comments where appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7799
diff
changeset
|
89 ; Revision 1.20 1994/06/05 16:57:22 tromey |
7d4674a34de3
Added ";;;###autoload" comments where appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7799
diff
changeset
|
90 ; tcl-current-word does the right thing in inferior-tcl-mode. |
7d4674a34de3
Added ";;;###autoload" comments where appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7799
diff
changeset
|
91 ; |
7799
1eb0d0f0f71b
tcl-current-word does the right thing in inferior-tcl-mode.
Tom Tromey <tromey@redhat.com>
parents:
7781
diff
changeset
|
92 ; Revision 1.19 1994/06/03 21:09:19 tromey |
1eb0d0f0f71b
tcl-current-word does the right thing in inferior-tcl-mode.
Tom Tromey <tromey@redhat.com>
parents:
7781
diff
changeset
|
93 ; Another menu fix. |
1eb0d0f0f71b
tcl-current-word does the right thing in inferior-tcl-mode.
Tom Tromey <tromey@redhat.com>
parents:
7781
diff
changeset
|
94 ; |
7781 | 95 ; Revision 1.18 1994/06/03 20:39:14 tromey |
96 ; Fixed menu bug. | |
97 ; | |
7780 | 98 ; Revision 1.17 1994/06/03 00:47:15 tromey |
99 ; Fixed bug in bug-reporting code. | |
100 ; | |
7771
f23eaf6babac
Fixed bug in bug-reporting code.
Tom Tromey <tromey@redhat.com>
parents:
7687
diff
changeset
|
101 ; Revision 1.16 1994/05/26 05:06:14 tromey |
f23eaf6babac
Fixed bug in bug-reporting code.
Tom Tromey <tromey@redhat.com>
parents:
7687
diff
changeset
|
102 ; Menu items now sensitive as appropriate. |
f23eaf6babac
Fixed bug in bug-reporting code.
Tom Tromey <tromey@redhat.com>
parents:
7687
diff
changeset
|
103 ; |
7687
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
104 ; Revision 1.15 1994/05/22 20:38:11 tromey |
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
105 ; Added bug-report keybindings and menu entries. |
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
106 ; |
7635
b5acd78a49e3
Added bug-report keybindings and menu entries.
Tom Tromey <tromey@redhat.com>
parents:
7633
diff
changeset
|
107 ; Revision 1.14 1994/05/22 20:18:28 tromey |
b5acd78a49e3
Added bug-report keybindings and menu entries.
Tom Tromey <tromey@redhat.com>
parents:
7633
diff
changeset
|
108 ; Even more compile stuff. |
b5acd78a49e3
Added bug-report keybindings and menu entries.
Tom Tromey <tromey@redhat.com>
parents:
7633
diff
changeset
|
109 ; |
7633 | 110 ; Revision 1.13 1994/05/22 20:17:15 tromey |
111 ; Moved emacs version checking code to very beginning. | |
112 ; | |
7631
89a1e55c615d
Moved emacs version checking code to very beginning.
Tom Tromey <tromey@redhat.com>
parents:
7630
diff
changeset
|
113 ; Revision 1.12 1994/05/22 20:14:59 tromey |
89a1e55c615d
Moved emacs version checking code to very beginning.
Tom Tromey <tromey@redhat.com>
parents:
7630
diff
changeset
|
114 ; Compile fixes. |
89a1e55c615d
Moved emacs version checking code to very beginning.
Tom Tromey <tromey@redhat.com>
parents:
7630
diff
changeset
|
115 ; |
7630 | 116 ; Revision 1.11 1994/05/22 20:12:44 tromey |
117 ; Fixed mark-defun for 19.23. | |
118 ; More menu fixes. | |
119 ; | |
7629
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
120 ; Revision 1.10 1994/05/22 20:02:03 tromey |
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
121 ; Fixed bug with M-;. |
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
122 ; Wrote bug-reporting code. |
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
123 ; |
7628 | 124 ; Revision 1.9 1994/05/22 05:26:51 tromey |
125 ; Fixes for imenu. | |
126 ; | |
7613 | 127 ; Revision 1.8 1994/05/22 03:38:07 tromey |
128 ; Fixed menu support. | |
129 ; | |
7612 | 130 ; Revision 1.7 1994/05/03 01:23:42 tromey |
131 ; *** empty log message *** | |
132 ; | |
7288 | 133 ; Revision 1.6 1994/04/23 16:23:36 tromey |
134 ; Wrote tcl-indent-for-comment | |
135 ; | |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
136 ;; |
6709 | 137 ;; 18-Mar-1994 Tom Tromey Fourth beta release. |
138 ;; Added {un,}comment-region to menu. Idea from | |
139 ;; Mike Scheidler <c23mts@kocrsv01.delcoelect.com> | |
140 ;; 17-Mar-1994 Tom Tromey | |
141 ;; Fixed tcl-restart-with-file. Bug fix attempt in | |
142 ;; tcl-internal-end-of-defun. | |
143 ;; 16-Mar-1994 Tom Tromey Third beta release | |
144 ;; Added support code for menu (from Tcl mode written by | |
145 ;; schmid@fb3-s7.math.TU-Berlin.DE (Gregor Schmid)). | |
146 ;; 12-Mar-1994 Tom Tromey | |
147 ;; Better documentation for inferior-tcl-buffer. Wrote | |
148 ;; tcl-restart-with-file. Wrote Lucid Emacs menu (but no | |
149 ;; code to install it). | |
150 ;; 12-Mar-1994 Tom Tromey | |
151 ;; Wrote tcl-guess-application. Another stab at making | |
152 ;; tcl-omit-ws-regexp work. | |
153 ;; 10-Mar-1994 Tom Tromey Second beta release | |
154 ;; Last Modified: Thu Mar 10 01:24:25 1994 (Tom Tromey) | |
155 ;; Wrote perl-mode style line indentation command. | |
156 ;; Wrote more documentation. Added tcl-continued-indent-level. | |
157 ;; Integrated help code. | |
158 ;; 8-Mar-1994 Tom Tromey | |
159 ;; Last Modified: Tue Mar 8 11:58:44 1994 (Tom Tromey) | |
160 ;; Bug fixes. | |
161 ;; 6-Mar-1994 Tom Tromey | |
162 ;; Last Modified: Sun Mar 6 18:55:41 1994 (Tom Tromey) | |
163 ;; Updated auto-newline support. | |
164 ;; 6-Mar-1994 Tom Tromey Beta release | |
165 ;; Last Modified: Sat Mar 5 17:24:32 1994 (Tom Tromey) | |
166 ;; Wrote tcl-hashify-buffer. Other minor bug fixes. | |
167 ;; 5-Mar-1994 Tom Tromey | |
168 ;; Last Modified: Sat Mar 5 16:11:20 1994 (Tom Tromey) | |
169 ;; Wrote electric-hash code. | |
170 ;; 3-Mar-1994 Tom Tromey | |
171 ;; Last Modified: Thu Mar 3 02:53:40 1994 (Tom Tromey) | |
172 ;; Added code to handle auto-fill in comments. | |
173 ;; Added imenu support code. | |
174 ;; Cleaned up code. | |
175 ;; Better font-lock support. | |
176 ;; 28-Feb-1994 Tom Tromey | |
177 ;; Last Modified: Mon Feb 28 14:08:05 1994 (Tom Tromey) | |
178 ;; Made tcl-figure-type more easily configurable. | |
179 ;; 28-Feb-1994 Tom Tromey | |
180 ;; Last Modified: Mon Feb 28 01:02:58 1994 (Tom Tromey) | |
181 ;; Wrote inferior-tcl mode. | |
182 ;; 16-Feb-1994 Tom Tromey | |
183 ;; Last Modified: Wed Feb 16 17:05:19 1994 (Tom Tromey) | |
184 ;; Added support for font-lock-mode. | |
185 ;; 29-Oct-1993 Tom Tromey | |
186 ;; Last Modified: Sun Oct 24 17:39:14 1993 (Tom Tromey) | |
187 ;; Patches from Guido Bosch to make things work with Lucid Emacs. | |
188 ;; 22-Oct-1993 Tom Tromey | |
189 ;; Last Modified: Fri Oct 22 15:26:46 1993 (Tom Tromey) | |
190 ;; Made many characters have "_" syntax class; suggested by Guido | |
191 ;; Bosch <Guido.Bosch@loria.fr>. Note that this includes the "$" | |
192 ;; character, which might be a change you'd notice. | |
193 ;; 21-Oct-1993 Tom Tromey | |
194 ;; Last Modified: Thu Oct 21 20:28:40 1993 (Tom Tromey) | |
195 ;; More fixes for tcl-omit-ws-regexp. | |
196 ;; 20-Oct-1993 Tom Tromey | |
197 ;; Started keeping history. Fixed tcl-{beginning,end}-of-defun. | |
198 ;; Added some code to make things work with Emacs 18. | |
199 | |
200 ;; THANKS TO: | |
201 ;; Guido Bosch <Guido.Bosch@loria.fr> | |
202 ;; pgs1002@esc.cam.ac.uk (Dr P.G. Sjoerdsma) | |
203 ;; Mike Scheidler <c23mts@kocrsv01.delcoelect.com> | |
204 ;; Matt Newman <men@charney.colorado.edu> | |
205 ;; rwhitby@research.canon.oz.au (Rod Whitby) | |
206 ;; h9118101@hkuxa.hku.hk (Yip Chi Lap [Beta]) | |
207 ;; Pertti Tapio Kasanen <ptk@delta.hut.fi> | |
208 ;; schmid@fb3-s7.math.TU-Berlin.DE (Gregor Schmid) | |
8339
b6e4f16c969a
Emacs 18 changes from Carl Witty.
Tom Tromey <tromey@redhat.com>
parents:
8252
diff
changeset
|
209 ;; warsaw@nlm.nih.gov (Barry A. Warsaw) |
b6e4f16c969a
Emacs 18 changes from Carl Witty.
Tom Tromey <tromey@redhat.com>
parents:
8252
diff
changeset
|
210 ;; Carl Witty <cwitty@ai.mit.edu> |
8580
648f78c8ecf5
Fixed bug in tcl-guess-application.
Tom Tromey <tromey@redhat.com>
parents:
8575
diff
changeset
|
211 ;; T. V. Raman <raman@crl.dec.com> |
11303
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
212 ;; Jesper Pedersen <blackie@imada.ou.dk> |
6709 | 213 |
214 ;; KNOWN BUGS: | |
215 ;; * indent-region should skip blank lines. (It does in v19, so I'm | |
216 ;; not motivated to fix it here). | |
217 ;; * In Tcl "#" is not always a comment character. This can confuse | |
218 ;; tcl.el in certain circumstances. For now the only workaround is | |
219 ;; to enclose offending hash characters in quotes or precede it with | |
220 ;; a backslash. Note that using braces won't work -- quotes change | |
221 ;; the syntax class of characters between them, while braces do not. | |
222 ;; The electric-# mode helps alleviate this problem somewhat. | |
223 ;; * indent-tcl-exp is untested. | |
224 ;; * Doesn't work under Emacs 18 yet. | |
225 ;; * There's been a report that font-lock does strange things under | |
226 ;; Lucid Emacs 19.6. For instance in "proc foobar", the space | |
227 ;; before "foobar" is highlighted. | |
228 | |
229 ;; TODO: | |
230 ;; * make add-log-tcl-defun smarter. should notice if we are in the | |
231 ;; middle of a defun, or between defuns. should notice if point is | |
232 ;; on first line of defun (or maybe even in comments before defun). | |
233 ;; * Allow continuation lines to be indented under the first argument | |
234 ;; of the preceeding line, like this: | |
235 ;; [list something \ | |
236 ;; something-else] | |
237 ;; * There is a request that indentation work like this: | |
238 ;; button .fred -label Fred \ | |
239 ;; -command {puts fred} | |
240 ;; * Should have tcl-complete-symbol that queries the inferior process. | |
241 ;; * Should have describe-symbol that works by sending the magic | |
242 ;; command to a tclX process. | |
243 ;; * Need C-x C-e binding (tcl-eval-last-exp). | |
244 ;; * Write indent-region function that is faster than indenting each | |
245 ;; line individually. | |
246 ;; * tcl-figure-type should stop at "beginning of line" (only ws | |
247 ;; before point, and no "\" on previous line). (see tcl-real-command-p). | |
248 ;; * overrides some comint keybindings; fix. | |
249 ;; * Trailing \ will eat blank lines. Should deal with this. | |
250 ;; (this would help catch some potential bugs). | |
251 ;; * Inferior should display in half the screen, not the whole screen. | |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
252 ;; * Indentation should deal with "switch". |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
253 ;; * Consider writing code to find help files automatically (for |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
254 ;; common cases). |
7628 | 255 ;; * `#' shouldn't insert `\#' when point is in string. |
7687
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
256 ;; * '}' doesn't seem to reindent. |
6709 | 257 |
258 | |
259 | |
260 ;;; Code: | |
261 | |
7631
89a1e55c615d
Moved emacs version checking code to very beginning.
Tom Tromey <tromey@redhat.com>
parents:
7630
diff
changeset
|
262 ;; I sure wish Emacs had a package that made it easy to extract this |
89a1e55c615d
Moved emacs version checking code to very beginning.
Tom Tromey <tromey@redhat.com>
parents:
7630
diff
changeset
|
263 ;; sort of information. |
89a1e55c615d
Moved emacs version checking code to very beginning.
Tom Tromey <tromey@redhat.com>
parents:
7630
diff
changeset
|
264 (defconst tcl-using-emacs-19 (string-match "19\\." emacs-version) |
89a1e55c615d
Moved emacs version checking code to very beginning.
Tom Tromey <tromey@redhat.com>
parents:
7630
diff
changeset
|
265 "Nil unless using Emacs 19 (Lucid or FSF).") |
89a1e55c615d
Moved emacs version checking code to very beginning.
Tom Tromey <tromey@redhat.com>
parents:
7630
diff
changeset
|
266 |
89a1e55c615d
Moved emacs version checking code to very beginning.
Tom Tromey <tromey@redhat.com>
parents:
7630
diff
changeset
|
267 ;; FIXME this will break on Emacs 19.100. |
8339
b6e4f16c969a
Emacs 18 changes from Carl Witty.
Tom Tromey <tromey@redhat.com>
parents:
8252
diff
changeset
|
268 (defconst tcl-using-emacs-19-23 |
7631
89a1e55c615d
Moved emacs version checking code to very beginning.
Tom Tromey <tromey@redhat.com>
parents:
7630
diff
changeset
|
269 (string-match "19\\.\\(2[3-9]\\|[3-9][0-9]\\)" emacs-version) |
8339
b6e4f16c969a
Emacs 18 changes from Carl Witty.
Tom Tromey <tromey@redhat.com>
parents:
8252
diff
changeset
|
270 "Nil unless using Emacs 19-23 or later.") |
7631
89a1e55c615d
Moved emacs version checking code to very beginning.
Tom Tromey <tromey@redhat.com>
parents:
7630
diff
changeset
|
271 |
89a1e55c615d
Moved emacs version checking code to very beginning.
Tom Tromey <tromey@redhat.com>
parents:
7630
diff
changeset
|
272 (defconst tcl-using-lemacs-19 (string-match "Lucid" emacs-version) |
89a1e55c615d
Moved emacs version checking code to very beginning.
Tom Tromey <tromey@redhat.com>
parents:
7630
diff
changeset
|
273 "Nil unless using Lucid Emacs).") |
89a1e55c615d
Moved emacs version checking code to very beginning.
Tom Tromey <tromey@redhat.com>
parents:
7630
diff
changeset
|
274 |
6709 | 275 (require 'comint) |
276 | |
7630 | 277 ;; When compiling under GNU Emacs, load imenu during compilation. If |
278 ;; you have 19.22 or earlier, comment this out, or get imenu. | |
279 (and (fboundp 'eval-when-compile) | |
280 (eval-when-compile | |
7633 | 281 (if (and (string-match "19\\." emacs-version) |
282 (not (string-match "Lucid" emacs-version))) | |
7630 | 283 (require 'imenu)) |
284 ())) | |
285 | |
11303
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
286 (defconst tcl-version "$Revision: 1.27 $") |
7628 | 287 (defconst tcl-maintainer "Tom Tromey <tromey@busco.lanl.gov>") |
288 | |
6709 | 289 ;; |
290 ;; User variables. | |
291 ;; | |
292 | |
293 (defvar tcl-indent-level 4 | |
294 "*Indentation of Tcl statements with respect to containing block.") | |
295 | |
296 (defvar tcl-continued-indent-level 4 | |
297 "*Indentation of continuation line relative to first line of command.") | |
298 | |
299 (defvar tcl-auto-newline nil | |
300 "*Non-nil means automatically newline before and after braces | |
301 inserted in Tcl code.") | |
302 | |
303 (defvar tcl-tab-always-indent t | |
304 "*Control effect of TAB key. | |
305 If t (the default), always indent current line. | |
306 If nil and point is not in the indentation area at the beginning of | |
307 the line, a TAB is inserted. | |
308 Other values cause the first possible action from the following list | |
309 to take place: | |
310 | |
311 1. Move from beginning of line to correct indentation. | |
312 2. Delete an empty comment. | |
313 3. Move forward to start of comment, indenting if necessary. | |
314 4. Move forward to end of line, indenting if necessary. | |
315 5. Create an empty comment. | |
316 6. Move backward to start of comment, indenting if necessary.") | |
317 | |
318 (defvar tcl-use-hairy-comment-detector t | |
319 "*If not `nil', the the more complicated, but slower, comment | |
320 detecting function is used. This variable is only used in GNU Emacs | |
321 19 (the fast function is always used elsewhere).") | |
322 | |
323 (defvar tcl-electric-hash-style 'smart | |
324 "*Style of electric hash insertion to use. | |
325 Possible values are 'backslash, meaning that `\\' quoting should be | |
326 done; `quote, meaning that `\"' quoting should be done; 'smart, | |
327 meaning that the choice between 'backslash and 'quote should be | |
328 made depending on the number of hashes inserted; or nil, meaning that | |
329 no quoting should be done. Any other value for this variable is | |
330 taken to mean 'smart. The default is 'smart.") | |
331 | |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
332 (defvar tcl-help-directory-list nil |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
333 "*List of topmost directories containing TclX help files") |
6709 | 334 |
335 (defvar tcl-use-smart-word-finder t | |
336 "*If not nil, use a better way of finding the current word when | |
337 looking up help on a Tcl command.") | |
338 | |
339 (defvar tcl-application "wish" | |
340 "*Name of Tcl application to run in inferior Tcl mode.") | |
341 | |
342 (defvar tcl-command-switches nil | |
343 "*Switches to supply to `tcl-application'.") | |
344 | |
345 (defvar tcl-prompt-regexp "^\\(% \\|\\)" | |
346 "*If not nil, a regexp that will match the prompt in the inferior process. | |
347 If nil, the prompt is the name of the application with \">\" appended. | |
348 | |
349 The default is \"^\\(% \\|\\)\", which will match the default primary | |
350 and secondary prompts for tclsh and wish.") | |
351 | |
352 (defvar inferior-tcl-source-command "source %s\n" | |
353 "*Format-string for building a Tcl command to load a file. | |
354 This format string should use `%s' to substitute a file name | |
355 and should result in a Tcl expression that will command the | |
356 inferior Tcl to load that file. The filename will be appropriately | |
357 quoted for Tcl.") | |
358 | |
359 ;; | |
360 ;; Keymaps, abbrevs, syntax tables. | |
361 ;; | |
362 | |
363 (defvar tcl-mode-abbrev-table nil | |
364 "Abbrev table in use in Tcl-mode buffers.") | |
365 (if tcl-mode-abbrev-table | |
366 () | |
367 (define-abbrev-table 'tcl-mode-abbrev-table ())) | |
368 | |
369 (defvar tcl-mode-map () | |
370 "Keymap used in Tcl mode.") | |
371 | |
372 (defvar tcl-mode-syntax-table nil | |
373 "Syntax table in use in Tcl-mode buffers.") | |
374 (if tcl-mode-syntax-table | |
375 () | |
376 (setq tcl-mode-syntax-table (make-syntax-table)) | |
377 (modify-syntax-entry ?% "_" tcl-mode-syntax-table) | |
378 (modify-syntax-entry ?@ "_" tcl-mode-syntax-table) | |
379 (modify-syntax-entry ?& "_" tcl-mode-syntax-table) | |
380 (modify-syntax-entry ?* "_" tcl-mode-syntax-table) | |
381 (modify-syntax-entry ?+ "_" tcl-mode-syntax-table) | |
382 (modify-syntax-entry ?- "_" tcl-mode-syntax-table) | |
383 (modify-syntax-entry ?. "_" tcl-mode-syntax-table) | |
384 (modify-syntax-entry ?: "_" tcl-mode-syntax-table) | |
385 (modify-syntax-entry ?! "_" tcl-mode-syntax-table) | |
386 (modify-syntax-entry ?$ "_" tcl-mode-syntax-table) ; FIXME use "'"? | |
387 (modify-syntax-entry ?/ "_" tcl-mode-syntax-table) | |
388 (modify-syntax-entry ?~ "_" tcl-mode-syntax-table) | |
389 (modify-syntax-entry ?< "_" tcl-mode-syntax-table) | |
390 (modify-syntax-entry ?= "_" tcl-mode-syntax-table) | |
391 (modify-syntax-entry ?> "_" tcl-mode-syntax-table) | |
392 (modify-syntax-entry ?| "_" tcl-mode-syntax-table) | |
393 (modify-syntax-entry ?\( "()" tcl-mode-syntax-table) | |
394 (modify-syntax-entry ?\) ")(" tcl-mode-syntax-table) | |
395 (modify-syntax-entry ?\; "." tcl-mode-syntax-table) | |
396 (modify-syntax-entry ?\n "> " tcl-mode-syntax-table) | |
397 (modify-syntax-entry ?\f "> " tcl-mode-syntax-table) | |
398 (modify-syntax-entry ?# "< " tcl-mode-syntax-table)) | |
399 | |
400 (defvar inferior-tcl-mode-map nil | |
401 "Keymap used in Inferior Tcl mode.") | |
402 | |
403 ;; Lucid Emacs menu. | |
404 (defvar tcl-lucid-menu | |
405 '("Tcl" | |
406 ["Beginning of function" tcl-beginning-of-defun t] | |
407 ["End of function" tcl-end-of-defun t] | |
7629
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
408 ["Mark function" tcl-mark-defun t] |
7687
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
409 ["Indent region" indent-region (tcl-mark)] |
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
410 ["Comment region" comment-region (tcl-mark)] |
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
411 ["Uncomment region" tcl-uncomment-region (tcl-mark)] |
6709 | 412 "----" |
413 ["Show Tcl process buffer" inferior-tcl t] | |
7687
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
414 ["Send function to Tcl process" tcl-eval-defun |
7781 | 415 (and inferior-tcl-buffer (get-buffer inferior-tcl-buffer))] |
7687
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
416 ["Send region to Tcl process" tcl-eval-region |
7781 | 417 (and inferior-tcl-buffer (get-buffer inferior-tcl-buffer))] |
7687
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
418 ["Send file to Tcl process" tcl-load-file |
7781 | 419 (and inferior-tcl-buffer (get-buffer inferior-tcl-buffer))] |
6709 | 420 ["Restart Tcl process with file" tcl-restart-with-file t] |
421 "----" | |
7687
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
422 ["Tcl help" tcl-help-on-word tcl-help-directory-list] |
7635
b5acd78a49e3
Added bug-report keybindings and menu entries.
Tom Tromey <tromey@redhat.com>
parents:
7633
diff
changeset
|
423 ["Send bug report" tcl-submit-bug-report t]) |
7612 | 424 "Lucid Emacs menu for Tcl mode.") |
425 | |
426 ;; GNU Emacs does menus via keymaps. Do it in a function in case we | |
427 ;; later decide to add it to inferior Tcl mode as well. | |
428 (defun tcl-add-fsf-menu (map) | |
429 (define-key map [menu-bar] (make-sparse-keymap)) | |
7629
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
430 ;; This fails in Emacs 19.22 and earlier. |
7612 | 431 (require 'lmenu) |
7635
b5acd78a49e3
Added bug-report keybindings and menu entries.
Tom Tromey <tromey@redhat.com>
parents:
7633
diff
changeset
|
432 (let ((menu (make-lucid-menu-keymap "Tcl" (cdr tcl-lucid-menu)))) |
b5acd78a49e3
Added bug-report keybindings and menu entries.
Tom Tromey <tromey@redhat.com>
parents:
7633
diff
changeset
|
433 (define-key map [menu-bar tcl] (cons "Tcl" menu)) |
b5acd78a49e3
Added bug-report keybindings and menu entries.
Tom Tromey <tromey@redhat.com>
parents:
7633
diff
changeset
|
434 ;; The following is intended to compute the key sequence |
b5acd78a49e3
Added bug-report keybindings and menu entries.
Tom Tromey <tromey@redhat.com>
parents:
7633
diff
changeset
|
435 ;; information for the menu. It doesn't work. |
b5acd78a49e3
Added bug-report keybindings and menu entries.
Tom Tromey <tromey@redhat.com>
parents:
7633
diff
changeset
|
436 (x-popup-menu nil menu))) |
7612 | 437 |
438 (defun tcl-fill-mode-map () | |
439 (define-key tcl-mode-map "{" 'tcl-electric-char) | |
440 (define-key tcl-mode-map "}" 'tcl-electric-brace) | |
441 (define-key tcl-mode-map "[" 'tcl-electric-char) | |
442 (define-key tcl-mode-map "]" 'tcl-electric-char) | |
443 (define-key tcl-mode-map ";" 'tcl-electric-char) | |
444 (define-key tcl-mode-map "#" 'tcl-electric-hash) | |
445 ;; FIXME. | |
446 (define-key tcl-mode-map "\e\C-a" 'tcl-beginning-of-defun) | |
447 ;; FIXME. | |
448 (define-key tcl-mode-map "\e\C-e" 'tcl-end-of-defun) | |
449 ;; FIXME. | |
7629
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
450 (define-key tcl-mode-map "\e\C-h" 'tcl-mark-defun) |
7612 | 451 (define-key tcl-mode-map "\e\C-q" 'indent-tcl-exp) |
452 (define-key tcl-mode-map "\177" 'backward-delete-char-untabify) | |
453 (define-key tcl-mode-map "\t" 'tcl-indent-command) | |
454 (define-key tcl-mode-map "\M-;" 'tcl-indent-for-comment) | |
455 (define-key tcl-mode-map "\M-\C-x" 'tcl-eval-defun) | |
7635
b5acd78a49e3
Added bug-report keybindings and menu entries.
Tom Tromey <tromey@redhat.com>
parents:
7633
diff
changeset
|
456 (define-key tcl-mode-map "\C-c\C-b" 'tcl-submit-bug-report) |
7612 | 457 (and (fboundp 'comment-region) |
458 (define-key tcl-mode-map "\C-c\C-c" 'comment-region)) | |
8575
2d50d249caf4
Keybindings don't overshadown comint bindings.
Tom Tromey <tromey@redhat.com>
parents:
8339
diff
changeset
|
459 (define-key tcl-mode-map "\C-c\C-i" 'tcl-help-on-word) |
2d50d249caf4
Keybindings don't overshadown comint bindings.
Tom Tromey <tromey@redhat.com>
parents:
8339
diff
changeset
|
460 (define-key tcl-mode-map "\C-c\C-v" 'tcl-eval-defun) |
2d50d249caf4
Keybindings don't overshadown comint bindings.
Tom Tromey <tromey@redhat.com>
parents:
8339
diff
changeset
|
461 (define-key tcl-mode-map "\C-c\C-f" 'tcl-load-file) |
2d50d249caf4
Keybindings don't overshadown comint bindings.
Tom Tromey <tromey@redhat.com>
parents:
8339
diff
changeset
|
462 (define-key tcl-mode-map "\C-c\C-t" 'inferior-tcl) |
2d50d249caf4
Keybindings don't overshadown comint bindings.
Tom Tromey <tromey@redhat.com>
parents:
8339
diff
changeset
|
463 (define-key tcl-mode-map "\C-c\C-x" 'tcl-eval-region) |
2d50d249caf4
Keybindings don't overshadown comint bindings.
Tom Tromey <tromey@redhat.com>
parents:
8339
diff
changeset
|
464 (define-key tcl-mode-map "\C-c\C-s" 'switch-to-tcl) |
7612 | 465 |
466 ;; Make menus. | |
467 (if tcl-using-emacs-19 | |
468 (if tcl-using-lemacs-19 | |
469 ;; In Lucid, button 3 seems to be the standard for this. | |
470 (define-key tcl-mode-map 'button3 'tcl-popup-menu) | |
471 ;; In FSF 19, there is no standard, so I use shift-button2. | |
472 (tcl-add-fsf-menu tcl-mode-map) | |
473 (define-key tcl-mode-map [S-down-mouse-2] 'tcl-popup-menu)))) | |
474 | |
475 (defun tcl-fill-inferior-map () | |
8681
2fa333e36b60
Added filename completion in inferior tcl mode
Tom Tromey <tromey@redhat.com>
parents:
8581
diff
changeset
|
476 (define-key inferior-tcl-mode-map "\t" 'comint-dynamic-complete) |
2fa333e36b60
Added filename completion in inferior tcl mode
Tom Tromey <tromey@redhat.com>
parents:
8581
diff
changeset
|
477 (define-key inferior-tcl-mode-map "\M-?" |
2fa333e36b60
Added filename completion in inferior tcl mode
Tom Tromey <tromey@redhat.com>
parents:
8581
diff
changeset
|
478 'comint-dynamic-list-filename-completions) |
7612 | 479 (define-key inferior-tcl-mode-map "\e\C-a" 'tcl-beginning-of-defun) |
480 (define-key inferior-tcl-mode-map "\e\C-e" 'tcl-end-of-defun) | |
481 (define-key inferior-tcl-mode-map "\177" 'backward-delete-char-untabify) | |
482 (define-key inferior-tcl-mode-map "\M-\C-x" 'tcl-eval-defun) | |
7635
b5acd78a49e3
Added bug-report keybindings and menu entries.
Tom Tromey <tromey@redhat.com>
parents:
7633
diff
changeset
|
483 (define-key inferior-tcl-mode-map "\C-c\C-b" 'tcl-submit-bug-report) |
8575
2d50d249caf4
Keybindings don't overshadown comint bindings.
Tom Tromey <tromey@redhat.com>
parents:
8339
diff
changeset
|
484 (define-key inferior-tcl-mode-map "\C-c\C-i" 'tcl-help-on-word) |
2d50d249caf4
Keybindings don't overshadown comint bindings.
Tom Tromey <tromey@redhat.com>
parents:
8339
diff
changeset
|
485 (define-key inferior-tcl-mode-map "\C-c\C-v" 'tcl-eval-defun) |
2d50d249caf4
Keybindings don't overshadown comint bindings.
Tom Tromey <tromey@redhat.com>
parents:
8339
diff
changeset
|
486 (define-key inferior-tcl-mode-map "\C-c\C-f" 'tcl-load-file) |
2d50d249caf4
Keybindings don't overshadown comint bindings.
Tom Tromey <tromey@redhat.com>
parents:
8339
diff
changeset
|
487 (define-key inferior-tcl-mode-map "\C-c\C-t" 'inferior-tcl) |
2d50d249caf4
Keybindings don't overshadown comint bindings.
Tom Tromey <tromey@redhat.com>
parents:
8339
diff
changeset
|
488 (define-key inferior-tcl-mode-map "\C-c\C-x" 'tcl-eval-region) |
2d50d249caf4
Keybindings don't overshadown comint bindings.
Tom Tromey <tromey@redhat.com>
parents:
8339
diff
changeset
|
489 (define-key inferior-tcl-mode-map "\C-c\C-s" 'switch-to-tcl)) |
7612 | 490 |
491 (if tcl-mode-map | |
492 () | |
493 (setq tcl-mode-map (make-sparse-keymap)) | |
494 (tcl-fill-mode-map)) | |
495 | |
496 (if inferior-tcl-mode-map | |
497 () | |
498 ;; FIXME Use keymap inheritance here? FIXME we override comint | |
499 ;; keybindings here. Maybe someone has a better set? | |
500 (setq inferior-tcl-mode-map (copy-keymap comint-mode-map)) | |
501 (tcl-fill-inferior-map)) | |
502 | |
6709 | 503 |
504 (defvar inferior-tcl-buffer nil | |
505 "*The current inferior-tcl process buffer. | |
506 | |
507 MULTIPLE PROCESS SUPPORT | |
508 =========================================================================== | |
509 To run multiple Tcl processes, you start the first up with | |
510 \\[inferior-tcl]. It will be in a buffer named `*inferior-tcl*'. | |
511 Rename this buffer with \\[rename-buffer]. You may now start up a new | |
512 process with another \\[inferior-tcl]. It will be in a new buffer, | |
513 named `*inferior-tcl*'. You can switch between the different process | |
514 buffers with \\[switch-to-buffer]. | |
515 | |
516 Commands that send text from source buffers to Tcl processes -- like | |
517 `tcl-eval-defun' or `tcl-load-file' -- have to choose a process to | |
518 send to, when you have more than one Tcl process around. This is | |
519 determined by the global variable `inferior-tcl-buffer'. Suppose you | |
520 have three inferior Lisps running: | |
521 Buffer Process | |
522 foo inferior-tcl | |
523 bar inferior-tcl<2> | |
524 *inferior-tcl* inferior-tcl<3> | |
525 If you do a \\[tcl-eval-defun] command on some Lisp source code, what | |
526 process do you send it to? | |
527 | |
528 - If you're in a process buffer (foo, bar, or *inferior-tcl*), | |
529 you send it to that process. | |
530 - If you're in some other buffer (e.g., a source file), you | |
531 send it to the process attached to buffer `inferior-tcl-buffer'. | |
532 This process selection is performed by function `inferior-tcl-proc'. | |
533 | |
534 Whenever \\[inferior-tcl] fires up a new process, it resets | |
535 `inferior-tcl-buffer' to be the new process's buffer. If you only run | |
536 one process, this does the right thing. If you run multiple | |
537 processes, you can change `inferior-tcl-buffer' to another process | |
538 buffer with \\[set-variable].") | |
539 | |
540 ;; | |
541 ;; Hooks and other customization. | |
542 ;; | |
543 | |
544 (defvar tcl-mode-hook nil | |
545 "Hook run on entry to Tcl mode. | |
546 | |
547 Several functions exist which are useful to run from your | |
548 `tcl-mode-hook' (see each function's documentation for more | |
549 information): | |
550 | |
551 tcl-guess-application | |
552 Guesses a default setting for `tcl-application' based on any | |
553 \"#!\" line at the top of the file. | |
554 tcl-hashify-buffer | |
555 Quotes all \"#\" characters that don't correspond to actual | |
556 Tcl comments. (Useful when editing code not originally created | |
557 with this mode). | |
558 tcl-auto-fill-mode | |
559 Auto-filling of Tcl comments. | |
560 | |
561 Emacs 19 users can add functions to the hook with `add-hook': | |
562 | |
563 (add-hook 'tcl-mode-hook 'tcl-guess-application) | |
564 | |
565 Emacs 18 users must use `setq': | |
566 | |
567 (setq tcl-mode-hook (cons 'tcl-guess-application tcl-mode-hook))") | |
568 | |
569 | |
570 (defvar inferior-tcl-mode-hook nil | |
571 "Hook for customizing Inferior Tcl mode.") | |
572 | |
573 (defvar tcl-proc-list | |
574 '("proc") | |
575 "List of commands whose first argument defines something. | |
576 This exists because some people (eg, me) use \"defvar\" et al. | |
577 Call `tcl-set-proc-regexp' and `tcl-set-font-lock-keywords' | |
578 after changing this list.") | |
579 | |
580 (defvar tcl-proc-regexp nil | |
581 "Regexp to use when matching proc headers.") | |
582 | |
583 (defvar tcl-typeword-list | |
584 '("global" "upvar") | |
7612 | 585 "List of Tcl keywords denoting \"type\". Used only for highlighting. |
6709 | 586 Call `tcl-set-font-lock-keywords' after changing this list.") |
587 | |
588 ;; Generally I've picked control operators to be keywords. | |
589 (defvar tcl-keyword-list | |
590 '("if" "then" "else" "elseif" "for" "foreach" "break" "continue" "while" | |
591 "eval" "case" "in" "switch" "default" "exit" "error" "proc" "return" | |
592 "uplevel" "loop" "for_array_keys" "for_recursive_glob" "for_file") | |
593 "List of Tcl keywords. Used only for highlighting. | |
594 Default list includes some TclX keywords. | |
595 Call `tcl-set-font-lock-keywords' after changing this list.") | |
596 | |
597 (defvar tcl-font-lock-keywords nil | |
598 "Keywords to highlight for Tcl. See variable `font-lock-keywords'. | |
599 This variable is generally set from `tcl-proc-regexp', | |
600 `tcl-typeword-list', and `tcl-keyword-list' by the function | |
601 `tcl-set-font-lock-keywords'.") | |
602 | |
603 ;; FIXME need some way to recognize variables because array refs look | |
604 ;; like 2 sexps. | |
605 (defvar tcl-type-alist | |
606 '( | |
607 ("expr" tcl-expr) | |
608 ("catch" tcl-commands) | |
609 ("if" tcl-expr "then" tcl-commands) | |
610 ("elseif" tcl-expr "then" tcl-commands) | |
611 ("elseif" tcl-expr tcl-commands) | |
612 ("if" tcl-expr tcl-commands) | |
613 ("while" tcl-expr tcl-commands) | |
614 ("for" tcl-commands tcl-expr tcl-commands tcl-commands) | |
615 ("foreach" nil nil tcl-commands) | |
616 ("for_file" nil nil tcl-commands) | |
617 ("for_array_keys" nil nil tcl-commands) | |
618 ("for_recursive_glob" nil nil nil tcl-commands) | |
619 ;; Loop handling is not perfect, because the third argument can be | |
620 ;; either a command or an expr, and there is no real way to look | |
621 ;; forward. | |
622 ("loop" nil tcl-expr tcl-expr tcl-commands) | |
623 ("loop" nil tcl-expr tcl-commands) | |
624 ) | |
625 "Alist that controls indentation. | |
626 \(Actually, this really only controls what happens on continuation lines). | |
627 Each entry looks like `(KEYWORD TYPE ...)'. | |
628 Each type entry describes a sexp after the keyword, and can be one of: | |
629 * nil, meaning that this sexp has no particular type. | |
630 * tcl-expr, meaning that this sexp is an arithmetic expression. | |
631 * tcl-commands, meaning that this sexp holds Tcl commands. | |
632 * a string, which must exactly match the string at the corresponding | |
633 position for a match to be made. | |
634 | |
635 For example, the entry for the \"loop\" command is: | |
636 | |
637 (\"loop\" nil tcl-expr tcl-commands) | |
638 | |
639 This means that the \"loop\" command has three arguments. The first | |
640 argument is ignored (for indentation purposes). The second argument | |
641 is a Tcl expression, and the last argument is Tcl commands.") | |
642 | |
643 (defvar tcl-explain-indentation nil | |
644 "If not `nil', debugging message will be printed during indentation.") | |
645 | |
646 | |
647 | |
648 ;; | |
649 ;; Work around differences between various versions of Emacs. | |
650 ;; | |
651 | |
652 ;; We use this because Lemacs 19.9 has what we need. | |
653 (defconst tcl-pps-has-arg-6 | |
654 (or tcl-using-emacs-19 | |
655 (and tcl-using-lemacs-19 | |
656 (condition-case nil | |
657 (progn | |
658 (parse-partial-sexp (point) (point) nil nil nil t) | |
659 t) | |
660 (error nil)))) | |
661 "t if using an emacs which supports sixth (\"commentstop\") argument | |
662 to parse-partial-sexp.") | |
663 | |
664 ;; Its pretty bogus to have to do this, but there is no easier way to | |
665 ;; say "match not syntax-1 and not syntax-2". Too bad you can't put | |
666 ;; \s in [...]. This sickness is used in Emacs 19 to match a defun | |
667 ;; starter. (It is used for this in v18 as well). | |
668 ;;(defconst tcl-omit-ws-regexp | |
669 ;; (concat "^\\(\\s" | |
670 ;; (mapconcat 'char-to-string "w_.()\"\\$'/" "\\|\\s") | |
671 ;; "\\)\\S(*") | |
672 ;; "Regular expression that matches everything except space, comment | |
673 ;;starter, and comment ender syntax codes.") | |
674 | |
675 ;; FIXME? Instead of using the hairy regexp above, we just use a | |
676 ;; simple one. | |
677 ;;(defconst tcl-omit-ws-regexp "^[^] \t\n#}]\\S(*" | |
678 ;; "Regular expression used in locating function definitions.") | |
679 | |
680 ;; Here's another stab. I think this one actually works. Now the | |
681 ;; problem seems to be that there is a bug in Emacs 19.22 where | |
682 ;; end-of-defun doesn't really use the brace matching the one that | |
683 ;; trails defun-prompt-regexp. | |
684 (defconst tcl-omit-ws-regexp "^[^ \t\n#}][^\n}]+}*[ \t]+") | |
685 | |
686 (defun tcl-internal-beginning-of-defun (&optional arg) | |
687 "Move backward to next beginning-of-defun. | |
688 With argument, do this that many times. | |
689 Returns t unless search stops due to end of buffer." | |
690 (interactive "p") | |
691 (if (or (null arg) (= arg 0)) | |
692 (setq arg 1)) | |
693 (let (success) | |
694 (while (progn | |
695 (setq arg (1- arg)) | |
696 (and (>= arg 0) | |
697 (setq success | |
698 (re-search-backward tcl-omit-ws-regexp nil 'move 1)))) | |
699 (while (and (looking-at "[]#}]") | |
700 (setq success | |
701 (re-search-backward tcl-omit-ws-regexp nil 'move 1))))) | |
702 (beginning-of-line) | |
703 (not (null success)))) | |
704 | |
705 (defun tcl-internal-end-of-defun (&optional arg) | |
706 "Move forward to next end of defun. | |
707 An end of a defun is found by moving forward from the beginning of one." | |
708 (interactive "p") | |
709 (if (or (null arg) (= arg 0)) (setq arg 1)) | |
710 (let ((start (point))) | |
711 ;; Was forward-char. I think this works a little better. | |
712 (forward-line) | |
713 (tcl-beginning-of-defun) | |
714 (while (> arg 0) | |
715 (while (and (re-search-forward tcl-omit-ws-regexp nil 'move 1) | |
716 (progn (beginning-of-line) t) | |
717 (looking-at "[]#}]") | |
718 (progn (forward-line) t))) | |
719 (let ((next-line (save-excursion | |
720 (forward-line) | |
721 (point)))) | |
722 (while (< (point) next-line) | |
723 (forward-sexp))) | |
724 (forward-line) | |
725 (if (> (point) start) (setq arg (1- arg)))))) | |
726 | |
727 ;; In Emacs 19, we can use begining-of-defun as long as we set up a | |
728 ;; certain regexp. In Emacs 18, we need our own function. | |
729 (fset 'tcl-beginning-of-defun | |
730 (if tcl-using-emacs-19 | |
731 'beginning-of-defun | |
732 'tcl-internal-beginning-of-defun)) | |
733 | |
7629
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
734 ;; Ditto end-of-defun. |
6709 | 735 (fset 'tcl-end-of-defun |
7629
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
736 (if tcl-using-emacs-19 |
6709 | 737 'end-of-defun |
738 'tcl-internal-end-of-defun)) | |
739 | |
7629
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
740 ;; Internal mark-defun that is used for losing Emacsen. |
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
741 (defun tcl-internal-mark-defun () |
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
742 "Put mark at end of Tcl function, point at beginning." |
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
743 (interactive) |
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
744 (push-mark (point)) |
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
745 (tcl-end-of-defun) |
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
746 (if tcl-using-emacs-19 |
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
747 (push-mark (point) nil t) |
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
748 (push-mark (point))) |
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
749 (tcl-beginning-of-defun) |
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
750 (backward-paragraph)) |
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
751 |
8339
b6e4f16c969a
Emacs 18 changes from Carl Witty.
Tom Tromey <tromey@redhat.com>
parents:
8252
diff
changeset
|
752 ;; In GNU Emacs 19-23 and later, mark-defun works as advertised. I |
7629
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
753 ;; don't know about Lucid Emacs, so for now it and Emacs 18 just lose. |
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
754 (fset 'tcl-mark-defun |
8339
b6e4f16c969a
Emacs 18 changes from Carl Witty.
Tom Tromey <tromey@redhat.com>
parents:
8252
diff
changeset
|
755 (if tcl-using-emacs-19-23 |
7629
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
756 'mark-defun |
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
757 'tcl-internal-mark-defun)) |
5f634da854fd
Fixed mark-defun for 19.23.
Tom Tromey <tromey@redhat.com>
parents:
7628
diff
changeset
|
758 |
7687
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
759 ;; In GNU Emacs 19, mark takes an additional "force" argument. I |
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
760 ;; don't know about Lucid Emacs, so I'm just assuming it is the same. |
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
761 ;; Emacs 18 doesn't have this argument. |
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
762 (defun tcl-mark () |
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
763 "Return mark, or nil if none." |
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
764 (if tcl-using-emacs-19 |
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
765 (mark t) |
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
766 (mark))) |
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
767 |
6709 | 768 |
769 | |
770 ;; | |
771 ;; Some helper functions. | |
772 ;; | |
773 | |
774 (defun tcl-set-proc-regexp () | |
775 "Set `tcl-proc-regexp' from variable `tcl-proc-list'." | |
776 (setq tcl-proc-regexp (concat "^\\(" | |
777 (mapconcat 'identity tcl-proc-list "\\|") | |
778 "\\)[ \t]+"))) | |
779 | |
780 (defun tcl-set-font-lock-keywords () | |
781 "Set `tcl-font-lock-keywords'. | |
782 Uses variables `tcl-proc-regexp' and `tcl-keyword-list'." | |
783 (setq tcl-font-lock-keywords | |
784 (list | |
785 ;; Names of functions (and other "defining things"). | |
786 (list (concat tcl-proc-regexp "\\([^ \t\n]+\\)") | |
787 2 'font-lock-function-name-face) | |
788 | |
789 ;; Names of type-defining things. | |
790 (list (concat "\\(\\s-\\|^\\)\\(" | |
791 ;; FIXME Use 'regexp-quote? | |
792 (mapconcat 'identity tcl-typeword-list "\\|") | |
793 "\\)\\(\\s-\\|$\\)") | |
794 2 'font-lock-type-face) | |
795 | |
796 ;; Keywords. Only recognized if surrounded by whitespace. | |
797 ;; FIXME consider using "not word or symbol", not | |
798 ;; "whitespace". | |
799 (cons (concat "\\(\\s-\\|^\\)\\(" | |
800 ;; FIXME Use regexp-quote? | |
801 (mapconcat 'identity tcl-keyword-list "\\|") | |
802 "\\)\\(\\s-\\|$\\)") | |
803 2) | |
804 ))) | |
805 | |
806 (if tcl-proc-regexp | |
807 () | |
808 (tcl-set-proc-regexp)) | |
809 | |
810 (if tcl-font-lock-keywords | |
811 () | |
812 (tcl-set-font-lock-keywords)) | |
813 | |
814 | |
815 | |
816 ;; | |
817 ;; The mode itself. | |
818 ;; | |
819 | |
8252
7d4674a34de3
Added ";;;###autoload" comments where appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7799
diff
changeset
|
820 ;;;###autoload |
6709 | 821 (defun tcl-mode () |
822 "Major mode for editing Tcl code. | |
823 Expression and list commands understand all Tcl brackets. | |
824 Tab indents for Tcl code. | |
825 Paragraphs are separated by blank lines only. | |
826 Delete converts tabs to spaces as it moves back. | |
827 | |
828 Variables controlling indentation style: | |
829 tcl-indent-level | |
830 Indentation of Tcl statements within surrounding block. | |
831 tcl-continued-indent-level | |
832 Indentation of continuation line relative to first line of command. | |
833 | |
834 Variables controlling user interaction with mode (see variable | |
835 documentation for details): | |
836 tcl-tab-always-indent | |
837 Controls action of TAB key. | |
838 tcl-auto-newline | |
839 Non-nil means automatically newline before and after braces, brackets, | |
840 and semicolons inserted in Tcl code. | |
841 tcl-electric-hash-style | |
842 Controls action of `#' key. | |
843 tcl-use-hairy-comment-detector | |
844 If t, use more complicated, but slower, comment detector. | |
845 This variable is only used in GNU Emacs 19. | |
846 | |
847 Turning on Tcl mode calls the value of the variable `tcl-mode-hook' | |
848 with no args, if that value is non-nil. Read the documentation for | |
849 `tcl-mode-hook' to see what kinds of interesting hook functions | |
850 already exist. | |
851 | |
852 Commands: | |
853 \\{tcl-mode-map}" | |
854 (interactive) | |
855 (kill-all-local-variables) | |
856 (use-local-map tcl-mode-map) | |
857 (setq major-mode 'tcl-mode) | |
858 (setq mode-name "Tcl") | |
859 (setq local-abbrev-table tcl-mode-abbrev-table) | |
860 (set-syntax-table tcl-mode-syntax-table) | |
7612 | 861 |
6709 | 862 (make-local-variable 'paragraph-start) |
863 (setq paragraph-start (concat "^$\\|" page-delimiter)) | |
864 (make-local-variable 'paragraph-separate) | |
865 (setq paragraph-separate paragraph-start) | |
866 (make-local-variable 'paragraph-ignore-fill-prefix) | |
867 (setq paragraph-ignore-fill-prefix t) | |
7612 | 868 |
6709 | 869 (make-local-variable 'indent-line-function) |
870 (setq indent-line-function 'tcl-indent-line) | |
871 ;; Tcl doesn't require a final newline. | |
872 ;; (make-local-variable 'require-final-newline) | |
873 ;; (setq require-final-newline t) | |
7612 | 874 |
6709 | 875 (make-local-variable 'comment-start) |
876 (setq comment-start "# ") | |
877 (make-local-variable 'comment-start-skip) | |
878 (setq comment-start-skip "#+ *") | |
879 (make-local-variable 'comment-column) | |
880 (setq comment-column 40) | |
881 (make-local-variable 'comment-end) | |
882 (setq comment-end "") | |
7612 | 883 |
11303
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
884 (make-local-variable 'outline-regexp) |
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
885 (setq outline-regexp "[^\n\^M]") |
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
886 (make-local-variable 'outline-level) |
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
887 (setq outline-level 'tcl-outline-level) |
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
888 |
6709 | 889 (make-local-variable 'font-lock-keywords) |
890 (setq font-lock-keywords tcl-font-lock-keywords) | |
7613 | 891 |
892 ;; The following only really makes sense under GNU Emacs 19. | |
9428
3d5070024b68
(tcl-mode): imenu-create-index-function made buffer local.
Tom Tromey <tromey@redhat.com>
parents:
8681
diff
changeset
|
893 (make-local-variable 'imenu-create-index-function) |
6709 | 894 (setq imenu-create-index-function 'tcl-imenu-create-index-function) |
895 (make-local-variable 'parse-sexp-ignore-comments) | |
7612 | 896 |
6709 | 897 (if tcl-using-emacs-19 |
898 (progn | |
899 ;; This can only be set to t in Emacs 19 and Lucid Emacs. | |
900 ;; Emacs 18 and Epoch lose. | |
901 (setq parse-sexp-ignore-comments t) | |
902 ;; Lucid Emacs has defun-prompt-regexp, but I don't believe | |
903 ;; that it works for end-of-defun -- only for | |
904 ;; beginning-of-defun. | |
905 (make-local-variable 'defun-prompt-regexp) | |
906 (setq defun-prompt-regexp tcl-omit-ws-regexp) | |
907 ;; The following doesn't work in Lucid Emacs 19.6, but maybe | |
908 ;; it will appear in later versions. | |
909 (make-local-variable 'add-log-current-defun-function) | |
910 (setq add-log-current-defun-function 'add-log-tcl-defun)) | |
911 (setq parse-sexp-ignore-comments nil)) | |
7612 | 912 |
913 ;; Put Tcl menu into menubar for Lucid Emacs. This happens | |
914 ;; automatically for GNU Emacs. | |
915 (if (and tcl-using-lemacs-19 | |
916 current-menubar | |
917 (not (assoc "Tcl" current-menubar))) | |
918 (progn | |
919 (set-buffer-menubar (copy-sequence current-menubar)) | |
920 (add-menu nil "Tcl" tcl-lucid-menu))) | |
921 | |
6709 | 922 (run-hooks 'tcl-mode-hook)) |
923 | |
924 | |
925 | |
926 ;; This is used for braces, brackets, and semi (except for closing | |
927 ;; braces, which are handled specially). | |
928 (defun tcl-electric-char (arg) | |
929 "Insert character and correct line's indentation." | |
930 (interactive "p") | |
931 ;; Indent line first; this looks better if parens blink. | |
932 (tcl-indent-line) | |
933 (self-insert-command arg) | |
934 (if (and tcl-auto-newline (= last-command-char ?\;)) | |
935 (progn | |
936 (newline) | |
937 (tcl-indent-line)))) | |
938 | |
939 ;; This is used for closing braces. If tcl-auto-newline is set, can | |
940 ;; insert a newline both before and after the brace, depending on | |
941 ;; context. FIXME should this be configurable? Does anyone use this? | |
942 (defun tcl-electric-brace (arg) | |
943 "Insert character and correct line's indentation." | |
944 (interactive "p") | |
945 ;; If auto-newlining and there is stuff on the same line, insert a | |
946 ;; newline first. | |
947 (if tcl-auto-newline | |
948 (progn | |
949 (if (save-excursion | |
950 (skip-chars-backward " \t") | |
951 (bolp)) | |
952 () | |
953 (tcl-indent-line) | |
954 (newline)) | |
955 ;; In auto-newline case, must insert a newline after each | |
956 ;; brace. So an explicit loop is needed. | |
957 (while (> arg 0) | |
958 (insert last-command-char) | |
959 (tcl-indent-line) | |
960 (newline) | |
961 (setq arg (1- arg)))) | |
962 (self-insert-command arg)) | |
963 (tcl-indent-line)) | |
964 | |
965 | |
966 | |
967 (defun tcl-indent-command (&optional arg) | |
968 "Indent current line as Tcl code, or in some cases insert a tab character. | |
969 If tcl-tab-always-indent is t (the default), always indent current line. | |
970 If tcl-tab-always-indent is nil and point is not in the indentation | |
971 area at the beginning of the line, a TAB is inserted. | |
972 Other values of tcl-tab-always-indent cause the first possible action | |
973 from the following list to take place: | |
974 | |
975 1. Move from beginning of line to correct indentation. | |
976 2. Delete an empty comment. | |
977 3. Move forward to start of comment, indenting if necessary. | |
978 4. Move forward to end of line, indenting if necessary. | |
979 5. Create an empty comment. | |
980 6. Move backward to start of comment, indenting if necessary." | |
981 (interactive "p") | |
982 (cond | |
983 ((not tcl-tab-always-indent) | |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
984 ;; Indent if in indentation area, otherwise insert TAB. |
6709 | 985 (if (<= (current-column) (current-indentation)) |
986 (tcl-indent-line) | |
987 (self-insert-command arg))) | |
988 ((eq tcl-tab-always-indent t) | |
989 ;; Always indent. | |
990 (tcl-indent-line)) | |
991 (t | |
992 ;; "Perl-mode" style TAB command. | |
993 (let* ((ipoint (point)) | |
994 (eolpoint (progn | |
995 (end-of-line) | |
996 (point))) | |
997 (comment-p (tcl-in-comment))) | |
998 (cond | |
999 ((= ipoint (save-excursion | |
1000 (beginning-of-line) | |
1001 (point))) | |
1002 (beginning-of-line) | |
1003 (tcl-indent-line) | |
1004 ;; If indenting didn't leave us in column 0, go to the | |
1005 ;; indentation. Otherwise leave point at end of line. This | |
1006 ;; is a hack. | |
1007 (if (= (point) (save-excursion | |
1008 (beginning-of-line) | |
1009 (point))) | |
1010 (end-of-line) | |
1011 (back-to-indentation))) | |
1012 ((and comment-p (looking-at "[ \t]*$")) | |
1013 ;; Empty comment, so delete it. We also delete any ";" | |
1014 ;; characters at the end of the line. I think this is | |
1015 ;; friendlier, but I don't know how other people will feel. | |
1016 (backward-char) | |
1017 (skip-chars-backward " \t;") | |
1018 (delete-region (point) eolpoint)) | |
1019 ((and comment-p (< ipoint (point))) | |
1020 ;; Before comment, so skip to it. | |
1021 (tcl-indent-line) | |
1022 (indent-for-comment)) | |
1023 ((/= ipoint eolpoint) | |
1024 ;; Go to end of line (since we're not there yet). | |
1025 (goto-char eolpoint) | |
1026 (tcl-indent-line)) | |
1027 ((not comment-p) | |
1028 (tcl-indent-line) | |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1029 (tcl-indent-for-comment)) |
6709 | 1030 (t |
1031 ;; Go to start of comment. We don't leave point where it is | |
1032 ;; because we want to skip comment-start-skip. | |
1033 (tcl-indent-line) | |
1034 (indent-for-comment))))))) | |
1035 | |
1036 (defun tcl-indent-line () | |
1037 "Indent current line as Tcl code. | |
1038 Return the amount the indentation changed by." | |
1039 (let ((indent (calculate-tcl-indent nil)) | |
1040 beg shift-amt | |
1041 (case-fold-search nil) | |
1042 (pos (- (point-max) (point)))) | |
1043 (beginning-of-line) | |
1044 (setq beg (point)) | |
1045 (cond ((eq indent nil) | |
1046 (setq indent (current-indentation))) | |
1047 (t | |
1048 (skip-chars-forward " \t") | |
1049 (if (listp indent) (setq indent (car indent))) | |
1050 (cond ((= (following-char) ?}) | |
1051 (setq indent (- indent tcl-indent-level))) | |
1052 ((= (following-char) ?\]) | |
1053 (setq indent (- indent 1)))))) | |
1054 (skip-chars-forward " \t") | |
1055 (setq shift-amt (- indent (current-column))) | |
1056 (if (zerop shift-amt) | |
1057 (if (> (- (point-max) pos) (point)) | |
1058 (goto-char (- (point-max) pos))) | |
1059 (delete-region beg (point)) | |
1060 (indent-to indent) | |
1061 ;; If initial point was within line's indentation, | |
1062 ;; position after the indentation. Else stay at same point in text. | |
1063 (if (> (- (point-max) pos) (point)) | |
1064 (goto-char (- (point-max) pos)))) | |
1065 shift-amt)) | |
1066 | |
1067 (defun tcl-figure-type () | |
1068 "Determine type of sexp at point. | |
1069 This is either 'tcl-expr, 'tcl-commands, or nil. Puts point at start | |
1070 of sexp that indicates types. | |
1071 | |
1072 See documentation for variable `tcl-type-alist' for more information." | |
1073 (let ((count 0) | |
1074 result | |
1075 word-stack) | |
1076 (while (and (< count 5) | |
1077 (not result)) | |
1078 (condition-case nil | |
1079 (progn | |
1080 ;; FIXME should use "tcl-backward-sexp", which would skip | |
1081 ;; over entire variables, etc. | |
1082 (backward-sexp) | |
1083 (if (looking-at "[a-zA-Z_]+") | |
1084 (let ((list tcl-type-alist) | |
1085 entry) | |
1086 (setq word-stack (cons (current-word) word-stack)) | |
1087 (while (and list (not result)) | |
1088 (setq entry (car list)) | |
1089 (setq list (cdr list)) | |
1090 (let ((index 0)) | |
1091 (while (and entry (<= index count)) | |
1092 ;; Abort loop if string does not match word on | |
1093 ;; stack. | |
1094 (and (stringp (car entry)) | |
1095 (not (string= (car entry) | |
1096 (nth index word-stack))) | |
1097 (setq entry nil)) | |
1098 (setq entry (cdr entry)) | |
1099 (setq index (1+ index))) | |
1100 (and (> index count) | |
1101 (not (stringp (car entry))) | |
1102 (setq result (car entry))) | |
1103 ))) | |
1104 (setq word-stack (cons nil word-stack)))) | |
1105 (error nil)) | |
1106 (setq count (1+ count))) | |
1107 (and tcl-explain-indentation | |
1108 (message "Indentation type %s" result)) | |
1109 result)) | |
1110 | |
1111 (defun calculate-tcl-indent (&optional parse-start) | |
1112 "Return appropriate indentation for current line as Tcl code. | |
1113 In usual case returns an integer: the column to indent to. | |
1114 Returns nil if line starts inside a string, t if in a comment." | |
1115 (save-excursion | |
1116 (beginning-of-line) | |
1117 (let* ((indent-point (point)) | |
1118 (case-fold-search nil) | |
1119 (continued-line | |
1120 (save-excursion | |
1121 (if (bobp) | |
1122 nil | |
1123 (backward-char) | |
1124 (= ?\\ (preceding-char))))) | |
1125 (continued-indent-value (if continued-line | |
1126 tcl-continued-indent-level | |
1127 0)) | |
1128 state | |
1129 containing-sexp | |
1130 found-next-line) | |
1131 (if parse-start | |
1132 (goto-char parse-start) | |
1133 (tcl-beginning-of-defun)) | |
1134 (while (< (point) indent-point) | |
1135 (setq parse-start (point)) | |
1136 (setq state (parse-partial-sexp (point) indent-point 0)) | |
1137 (setq containing-sexp (car (cdr state)))) | |
1138 (cond ((or (nth 3 state) (nth 4 state)) | |
1139 ;; Inside comment or string. Return nil or t if should | |
1140 ;; not change this line | |
1141 (nth 4 state)) | |
1142 ((null containing-sexp) | |
1143 ;; Line is at top level. | |
1144 continued-indent-value) | |
1145 (t | |
1146 ;; Set expr-p if we are looking at the expression part of | |
1147 ;; an "if", "expr", etc statement. Set commands-p if we | |
1148 ;; are looking at the body part of an if, while, etc | |
1149 ;; statement. FIXME Should check for "for" loops here. | |
1150 (goto-char containing-sexp) | |
1151 (let* ((sexpr-type (tcl-figure-type)) | |
1152 (expr-p (eq sexpr-type 'tcl-expr)) | |
1153 (commands-p (eq sexpr-type 'tcl-commands)) | |
1154 (expr-start (point))) | |
1155 ;; Find the first statement in the block and indent | |
1156 ;; like it. The first statement in the block might be | |
1157 ;; on the same line, so what we do is skip all | |
1158 ;; "virtually blank" lines, looking for a non-blank | |
1159 ;; one. A line is virtually blank if it only contains | |
1160 ;; a comment and whitespace. FIXME continued comments | |
1161 ;; aren't supported. They are a wart on Tcl anyway. | |
1162 ;; We do it this funky way because we want to know if | |
1163 ;; we've found a statement on some line _after_ the | |
1164 ;; line holding the sexp opener. | |
1165 (goto-char containing-sexp) | |
1166 (forward-char) | |
1167 (if (and (< (point) indent-point) | |
1168 (looking-at "[ \t]*\\(#.*\\)?$")) | |
1169 (progn | |
1170 (forward-line) | |
1171 (while (and (< (point) indent-point) | |
1172 (looking-at "[ \t]*\\(#.*\\)?$")) | |
1173 (setq found-next-line t) | |
1174 (forward-line)))) | |
1175 (if (or continued-line | |
1176 (/= (char-after containing-sexp) ?{) | |
1177 expr-p) | |
1178 (progn | |
1179 ;; Line is continuation line, or the sexp opener | |
1180 ;; is not a curly brace, or we are are looking at | |
1181 ;; an `expr' expression (which must be split | |
1182 ;; specially). So indentation is column of first | |
1183 ;; good spot after sexp opener (with some added | |
1184 ;; in the continued-line case). If there is no | |
1185 ;; nonempty line before the indentation point, we | |
1186 ;; use the column of the character after the sexp | |
1187 ;; opener. | |
1188 (if (>= (point) indent-point) | |
1189 (progn | |
1190 (goto-char containing-sexp) | |
1191 (forward-char)) | |
1192 (skip-chars-forward " \t")) | |
1193 (+ (current-column) continued-indent-value)) | |
1194 ;; After a curly brace, and not a continuation line. | |
1195 ;; So take indentation from first good line after | |
1196 ;; start of block, unless that line is on the same | |
1197 ;; line as the opening brace. In this case use the | |
1198 ;; indentation of the opening brace's line, plus | |
1199 ;; another indent step. If we are in the body part | |
1200 ;; of an "if" or "while" then the indentation is | |
1201 ;; taken from the line holding the start of the | |
1202 ;; statement. | |
1203 (if (and (< (point) indent-point) | |
1204 found-next-line) | |
1205 (current-indentation) | |
1206 (if commands-p | |
1207 (goto-char expr-start) | |
1208 (goto-char containing-sexp)) | |
1209 (+ (current-indentation) tcl-indent-level))))))))) | |
1210 | |
1211 | |
1212 | |
1213 (defun indent-tcl-exp () | |
1214 "Indent each line of the Tcl grouping following point." | |
1215 (interactive) | |
1216 (let ((indent-stack (list nil)) | |
1217 (contain-stack (list (point))) | |
1218 (case-fold-search nil) | |
1219 outer-loop-done inner-loop-done state ostate | |
1220 this-indent last-sexp continued-line | |
1221 (next-depth 0) | |
1222 last-depth) | |
1223 (save-excursion | |
1224 (forward-sexp 1)) | |
1225 (save-excursion | |
1226 (setq outer-loop-done nil) | |
1227 (while (and (not (eobp)) (not outer-loop-done)) | |
1228 (setq last-depth next-depth) | |
1229 ;; Compute how depth changes over this line | |
1230 ;; plus enough other lines to get to one that | |
1231 ;; does not end inside a comment or string. | |
1232 ;; Meanwhile, do appropriate indentation on comment lines. | |
1233 (setq inner-loop-done nil) | |
1234 (while (and (not inner-loop-done) | |
1235 (not (and (eobp) (setq outer-loop-done t)))) | |
1236 (setq ostate state) | |
1237 (setq state (parse-partial-sexp (point) (progn (end-of-line) (point)) | |
1238 nil nil state)) | |
1239 (setq next-depth (car state)) | |
1240 (if (and (car (cdr (cdr state))) | |
1241 (>= (car (cdr (cdr state))) 0)) | |
1242 (setq last-sexp (car (cdr (cdr state))))) | |
1243 (if (or (nth 4 ostate)) | |
1244 (tcl-indent-line)) | |
1245 (if (or (nth 3 state)) | |
1246 (forward-line 1) | |
1247 (setq inner-loop-done t))) | |
1248 (if (<= next-depth 0) | |
1249 (setq outer-loop-done t)) | |
1250 (if outer-loop-done | |
1251 nil | |
1252 ;; If this line had ..))) (((.. in it, pop out of the levels | |
1253 ;; that ended anywhere in this line, even if the final depth | |
1254 ;; doesn't indicate that they ended. | |
1255 (while (> last-depth (nth 6 state)) | |
1256 (setq indent-stack (cdr indent-stack) | |
1257 contain-stack (cdr contain-stack) | |
1258 last-depth (1- last-depth))) | |
1259 (if (/= last-depth next-depth) | |
1260 (setq last-sexp nil)) | |
1261 ;; Add levels for any parens that were started in this line. | |
1262 (while (< last-depth next-depth) | |
1263 (setq indent-stack (cons nil indent-stack) | |
1264 contain-stack (cons nil contain-stack) | |
1265 last-depth (1+ last-depth))) | |
1266 (if (null (car contain-stack)) | |
1267 (setcar contain-stack | |
1268 (or (car (cdr state)) | |
1269 (save-excursion | |
1270 (forward-sexp -1) | |
1271 (point))))) | |
1272 (forward-line 1) | |
1273 (setq continued-line | |
1274 (save-excursion | |
1275 (backward-char) | |
1276 (= (preceding-char) ?\\))) | |
1277 (skip-chars-forward " \t") | |
1278 (if (eolp) | |
1279 nil | |
1280 (if (and (car indent-stack) | |
1281 (>= (car indent-stack) 0)) | |
1282 ;; Line is on an existing nesting level. | |
1283 (setq this-indent (car indent-stack)) | |
1284 ;; Just started a new nesting level. | |
1285 ;; Compute the standard indent for this level. | |
1286 (let ((val (calculate-tcl-indent | |
1287 (if (car indent-stack) | |
1288 (- (car indent-stack)))))) | |
1289 (setcar indent-stack | |
1290 (setq this-indent val)) | |
1291 (setq continued-line nil))) | |
1292 (cond ((not (numberp this-indent))) | |
1293 ((= (following-char) ?}) | |
1294 (setq this-indent (- this-indent tcl-indent-level))) | |
1295 ((= (following-char) ?\]) | |
1296 (setq this-indent (- this-indent 1)))) | |
1297 ;; Put chosen indentation into effect. | |
1298 (or (null this-indent) | |
1299 (= (current-column) | |
1300 (if continued-line | |
1301 (+ this-indent tcl-indent-level) | |
1302 this-indent)) | |
1303 (progn | |
1304 (delete-region (point) (progn (beginning-of-line) (point))) | |
1305 (indent-to | |
1306 (if continued-line | |
1307 (+ this-indent tcl-indent-level) | |
1308 this-indent))))))))) | |
1309 ) | |
1310 | |
1311 | |
1312 | |
1313 ;; | |
1314 ;; Interfaces to other packages. | |
1315 ;; | |
1316 | |
1317 (defun tcl-imenu-create-index-function () | |
1318 "Generate alist of indices for imenu." | |
1319 (let ((re (concat tcl-proc-regexp "\\([^ \t\n{]+\\)")) | |
1320 alist) | |
1321 (imenu-progress-message 0) | |
1322 (goto-char (point-min)) | |
1323 (while (re-search-forward re nil t) | |
1324 (imenu-progress-message nil) | |
1325 ;; Position on start of proc name, not beginning of line. | |
1326 (setq alist (cons | |
1327 (cons (buffer-substring (match-beginning 2) (match-end 2)) | |
1328 (match-beginning 2)) | |
1329 alist))) | |
1330 (imenu-progress-message 100) | |
1331 (nreverse alist))) | |
1332 | |
1333 ;; FIXME Definition of function is very ad-hoc. Should use | |
1334 ;; tcl-beginning-of-defun. Also has incestuous knowledge about the | |
1335 ;; format of tcl-proc-regexp. | |
1336 (defun add-log-tcl-defun () | |
1337 "Return name of Tcl function point is in, or nil." | |
1338 (save-excursion | |
1339 (if (re-search-backward | |
1340 (concat tcl-proc-regexp "\\([^ \t\n{]+\\)") nil t) | |
1341 (buffer-substring (match-beginning 2) | |
1342 (match-end 2))))) | |
1343 | |
11303
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
1344 (defun tcl-outline-level () |
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
1345 (save-excursion |
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
1346 (skip-chars-forward " \t") |
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
1347 (current-column))) |
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
1348 |
6709 | 1349 |
1350 | |
1351 ;; | |
1352 ;; Helper functions for inferior Tcl mode. | |
1353 ;; | |
1354 | |
1355 ;; This exists to let us delete the prompt when commands are sent | |
1356 ;; directly to the inferior Tcl. See gud.el for an explanation of how | |
1357 ;; it all works (I took it from there). This stuff doesn't really | |
1358 ;; work as well as I'd like it to. But I don't believe there is | |
1359 ;; anything useful that can be done. | |
1360 (defvar inferior-tcl-delete-prompt-marker nil) | |
1361 | |
1362 (defun tcl-filter (proc string) | |
1363 (let ((inhibit-quit t)) | |
1364 (save-excursion | |
1365 (set-buffer (process-buffer proc)) | |
1366 (goto-char (process-mark proc)) | |
1367 ;; Delete prompt if requested. | |
1368 (if (marker-buffer inferior-tcl-delete-prompt-marker) | |
1369 (progn | |
1370 (delete-region (point) inferior-tcl-delete-prompt-marker) | |
1371 (set-marker inferior-tcl-delete-prompt-marker nil))))) | |
8339
b6e4f16c969a
Emacs 18 changes from Carl Witty.
Tom Tromey <tromey@redhat.com>
parents:
8252
diff
changeset
|
1372 (if tcl-using-emacs-19 |
b6e4f16c969a
Emacs 18 changes from Carl Witty.
Tom Tromey <tromey@redhat.com>
parents:
8252
diff
changeset
|
1373 (comint-output-filter proc string) |
b6e4f16c969a
Emacs 18 changes from Carl Witty.
Tom Tromey <tromey@redhat.com>
parents:
8252
diff
changeset
|
1374 (funcall comint-output-filter string))) |
6709 | 1375 |
1376 (defun tcl-send-string (proc string) | |
1377 (save-excursion | |
1378 (set-buffer (process-buffer proc)) | |
1379 (goto-char (process-mark proc)) | |
1380 (beginning-of-line) | |
1381 (if (looking-at comint-prompt-regexp) | |
1382 (set-marker inferior-tcl-delete-prompt-marker (point)))) | |
1383 (comint-send-string proc string)) | |
1384 | |
1385 (defun tcl-send-region (proc start end) | |
1386 (save-excursion | |
1387 (set-buffer (process-buffer proc)) | |
1388 (goto-char (process-mark proc)) | |
1389 (beginning-of-line) | |
1390 (if (looking-at comint-prompt-regexp) | |
1391 (set-marker inferior-tcl-delete-prompt-marker (point)))) | |
1392 (comint-send-region proc start end)) | |
1393 | |
1394 (defun switch-to-tcl (eob-p) | |
1395 "Switch to inferior Tcl process buffer. | |
1396 With argument, positions cursor at end of buffer." | |
1397 (interactive "P") | |
1398 (if (get-buffer inferior-tcl-buffer) | |
1399 (pop-to-buffer inferior-tcl-buffer) | |
1400 (error "No current inferior Tcl buffer")) | |
1401 (cond (eob-p | |
1402 (push-mark) | |
1403 (goto-char (point-max))))) | |
1404 | |
1405 (defun inferior-tcl-proc () | |
1406 "Return current inferior Tcl process. | |
1407 See variable `inferior-tcl-buffer'." | |
1408 (let ((proc (get-buffer-process (if (eq major-mode 'inferior-tcl-mode) | |
1409 (current-buffer) | |
1410 inferior-tcl-buffer)))) | |
1411 (or proc | |
1412 (error "No Tcl process; see variable `inferior-tcl-buffer'")))) | |
1413 | |
1414 (defun tcl-eval-region (start end &optional and-go) | |
1415 "Send the current region to the inferior Tcl process. | |
1416 Prefix argument means switch to the Tcl buffer afterwards." | |
1417 (interactive "r\nP") | |
1418 (let ((proc (inferior-tcl-proc))) | |
1419 (tcl-send-region proc start end) | |
1420 (tcl-send-string proc "\n") | |
1421 (if and-go (switch-to-tcl t)))) | |
1422 | |
1423 (defun tcl-eval-defun (&optional and-go) | |
1424 "Send the current defun to the inferior Tcl process. | |
1425 Prefix argument means switch to the Tcl buffer afterwards." | |
1426 (interactive "P") | |
1427 (save-excursion | |
1428 (tcl-end-of-defun) | |
1429 (let ((end (point))) | |
1430 (tcl-beginning-of-defun) | |
1431 (tcl-eval-region (point) end))) | |
1432 (if and-go (switch-to-tcl t))) | |
1433 | |
1434 | |
1435 | |
1436 ;; | |
1437 ;; Inferior Tcl mode itself. | |
1438 ;; | |
1439 | |
1440 (defun inferior-tcl-mode () | |
1441 "Major mode for interacting with Tcl interpreter. | |
1442 | |
1443 A Tcl process can be started with M-x inferior-tcl. | |
1444 | |
1445 Entry to this mode runs the hooks comint-mode-hook and | |
1446 inferior-tcl-mode-hook, in that order. | |
1447 | |
1448 You can send text to the inferior Tcl process from other buffers | |
1449 containing Tcl source. | |
1450 | |
1451 Variables controlling Inferior Tcl mode: | |
1452 tcl-application | |
1453 Name of program to run. | |
1454 tcl-command-switches | |
1455 Command line arguments to `tcl-application'. | |
1456 tcl-prompt-regexp | |
1457 Matches prompt. | |
1458 inferior-tcl-source-command | |
1459 Command to use to read Tcl file in running application. | |
1460 inferior-tcl-buffer | |
1461 The current inferior Tcl process buffer. See variable | |
1462 documentation for details on multiple-process support. | |
1463 | |
1464 The following commands are available: | |
1465 \\{inferior-tcl-mode-map}" | |
1466 (interactive) | |
1467 (comint-mode) | |
1468 (setq comint-prompt-regexp (or tcl-prompt-regexp | |
1469 (concat "^" | |
1470 (regexp-quote tcl-application) | |
1471 ">"))) | |
1472 (setq major-mode 'inferior-tcl-mode) | |
1473 (setq mode-name "Inferior Tcl") | |
1474 (setq mode-line-process '(": %s")) | |
1475 (use-local-map inferior-tcl-mode-map) | |
1476 (setq local-abbrev-table tcl-mode-abbrev-table) | |
1477 (set-syntax-table tcl-mode-syntax-table) | |
1478 (if tcl-using-emacs-19 | |
1479 (progn | |
1480 (make-local-variable 'defun-prompt-regexp) | |
1481 (setq defun-prompt-regexp tcl-omit-ws-regexp))) | |
1482 (make-local-variable 'inferior-tcl-delete-prompt-marker) | |
1483 (setq inferior-tcl-delete-prompt-marker (make-marker)) | |
1484 (set-process-filter (get-buffer-process (current-buffer)) 'tcl-filter) | |
1485 (run-hooks 'inferior-tcl-mode-hook)) | |
1486 | |
8252
7d4674a34de3
Added ";;;###autoload" comments where appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7799
diff
changeset
|
1487 ;;;###autoload |
6709 | 1488 (defun inferior-tcl (cmd) |
1489 "Run inferior Tcl process. | |
1490 Prefix arg means enter program name interactively. | |
1491 See documentation for function `inferior-tcl-mode' for more information." | |
1492 (interactive | |
1493 (list (if current-prefix-arg | |
1494 (read-string "Run Tcl: " tcl-application) | |
1495 tcl-application))) | |
1496 (if (not (comint-check-proc "*inferior-tcl*")) | |
1497 (progn | |
1498 (set-buffer (apply (function make-comint) "inferior-tcl" cmd nil | |
1499 tcl-command-switches)) | |
1500 (inferior-tcl-mode))) | |
1501 (make-local-variable 'tcl-application) | |
1502 (setq tcl-application cmd) | |
1503 (setq inferior-tcl-buffer "*inferior-tcl*") | |
1504 (switch-to-buffer "*inferior-tcl*")) | |
1505 | |
1506 (and (fboundp 'defalias) | |
1507 (defalias 'run-tcl 'inferior-tcl)) | |
1508 | |
1509 | |
1510 | |
1511 ;; | |
1512 ;; Auto-fill support. | |
1513 ;; | |
1514 | |
1515 (defun tcl-real-command-p () | |
1516 "Return nil if point is not at the beginning of a command. | |
1517 A command is the first word on an otherwise empty line, or the | |
1518 first word following a semicolon, opening brace, or opening bracket." | |
1519 (save-excursion | |
1520 (skip-chars-backward " \t") | |
1521 (cond | |
1522 ((bobp) t) | |
1523 ((bolp) | |
1524 (backward-char) | |
1525 ;; Note -- continued comments are not supported here. I | |
1526 ;; consider those to be a wart on the language. | |
1527 (not (eq ?\\ (preceding-char)))) | |
1528 (t | |
1529 (memq (preceding-char) '(?\; ?{ ?\[)))))) | |
1530 | |
1531 ;; FIXME doesn't actually return t. See last case. | |
1532 (defun tcl-real-comment-p () | |
1533 "Return t if point is just after the `#' beginning a real comment. | |
1534 Does not check to see if previous char is actually `#'. | |
1535 A real comment is either at the beginning of the buffer, | |
1536 preceeded only by whitespace on the line, or has a preceeding | |
1537 semicolon, opening brace, or opening bracket on the same line." | |
1538 (save-excursion | |
1539 (backward-char) | |
1540 (tcl-real-command-p))) | |
1541 | |
1542 (defun tcl-hairy-scan-for-comment (state end always-stop) | |
1543 "Determine if point is in a comment. | |
1544 Returns a list of the form `(FLAG . STATE)'. STATE can be used | |
1545 as input to future invocations. FLAG is nil if not in comment, | |
1546 t otherwise. If in comment, leaves point at beginning of comment. | |
1547 Only works in Emacs 19. See also `tcl-simple-scan-for-comment', a | |
1548 simpler version that is often right, and works in Emacs 18." | |
1549 (let ((bol (save-excursion | |
1550 (goto-char end) | |
1551 (beginning-of-line) | |
1552 (point))) | |
1553 real-comment | |
1554 last-cstart) | |
1555 (while (and (not last-cstart) (< (point) end)) | |
1556 (setq real-comment nil) ;In case we've looped around and it is | |
1557 ;set. | |
1558 (setq state (parse-partial-sexp (point) end nil nil state t)) | |
1559 (if (nth 4 state) | |
1560 (progn | |
1561 ;; If ALWAYS-STOP is set, stop even if we don't have a | |
1562 ;; real comment, or if the comment isn't on the same line | |
1563 ;; as the end. | |
1564 (if always-stop (setq last-cstart (point))) | |
1565 ;; If we have a real comment, then set the comment | |
1566 ;; starting point if we are on the same line as the ending | |
1567 ;; location. | |
1568 (setq real-comment (tcl-real-comment-p)) | |
1569 (if real-comment | |
1570 (progn | |
1571 (and (> (point) bol) (setq last-cstart (point))) | |
1572 ;; NOTE Emacs 19 has a misfeature whereby calling | |
1573 ;; parse-partial-sexp with COMMENTSTOP set and with | |
1574 ;; an initial list that says point is in a comment | |
1575 ;; will cause an immediate return. So we must skip | |
1576 ;; over the comment ourselves. | |
1577 (beginning-of-line 2))) | |
1578 ;; Frob the state to make it look like we aren't in a | |
1579 ;; comment. | |
1580 (setcar (nthcdr 4 state) nil)))) | |
1581 (and last-cstart | |
1582 (goto-char last-cstart)) | |
1583 (cons real-comment state))) | |
1584 | |
1585 (defun tcl-hairy-in-comment () | |
1586 "Return t if point is in a comment, and leave point at beginning | |
1587 of comment." | |
1588 (let ((save (point))) | |
1589 (tcl-beginning-of-defun) | |
1590 (car (tcl-hairy-scan-for-comment nil save nil)))) | |
7628 | 1591 |
6709 | 1592 (defun tcl-simple-in-comment () |
1593 "Return t if point is in comment, and leave point at beginning | |
1594 of comment. This is faster that `tcl-hairy-in-comment', but is | |
1595 correct less often." | |
1596 (let ((save (point)) | |
1597 comment) | |
1598 (beginning-of-line) | |
1599 (while (and (< (point) save) (not comment)) | |
1600 (search-forward "#" save 'move) | |
1601 (setq comment (tcl-real-comment-p))) | |
1602 comment)) | |
1603 | |
1604 (defun tcl-in-comment () | |
1605 "Return t if point is in comment, and leave point at beginning | |
1606 of comment." | |
1607 (if (and tcl-pps-has-arg-6 | |
1608 tcl-use-hairy-comment-detector) | |
1609 (tcl-hairy-in-comment) | |
1610 (tcl-simple-in-comment))) | |
1611 | |
1612 (defun tcl-do-auto-fill () | |
1613 "Auto-fill function for Tcl mode. Only auto-fills in a comment." | |
1614 (let (in-comment | |
1615 col) | |
1616 (save-excursion | |
1617 (setq in-comment (tcl-in-comment)) | |
1618 (if in-comment | |
1619 (setq col (1- (current-column))))) | |
1620 (if in-comment | |
1621 (progn | |
1622 (do-auto-fill) | |
1623 (save-excursion | |
1624 (back-to-indentation) | |
1625 (delete-region (point) (save-excursion | |
1626 (beginning-of-line) | |
1627 (point))) | |
1628 (indent-to-column col)))))) | |
1629 | |
1630 | |
1631 | |
1632 ;; | |
1633 ;; Help-related code. | |
1634 ;; | |
1635 | |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1636 (defvar tcl-help-saved-dirs nil |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1637 "Saved help directories. |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1638 If `tcl-help-directory-list' changes, this allows `tcl-help-on-word' |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1639 to update the alist.") |
6709 | 1640 |
1641 (defvar tcl-help-alist nil | |
1642 "Alist with command names as keys and filenames as values.") | |
1643 | |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1644 (defun tcl-help-snarf-commands (dirlist) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1645 "Build alist of commands and filenames." |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1646 (while dirlist |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1647 (let ((files (directory-files (car dirlist) t))) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1648 (while files |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1649 (if (and (file-directory-p (car files)) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1650 (not |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1651 (let ((fpart (file-name-nondirectory (car files)))) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1652 (or (equal fpart ".") |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1653 (equal fpart ".."))))) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1654 (let ((matches (directory-files (car files) t))) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1655 (while matches |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1656 (or (file-directory-p (car matches)) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1657 (setq tcl-help-alist |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1658 (cons |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1659 (cons (file-name-nondirectory (car matches)) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1660 (car matches)) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1661 tcl-help-alist))) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1662 (setq matches (cdr matches))))) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1663 (setq files (cdr files)))) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1664 (setq dirlist (cdr dirlist)))) |
6709 | 1665 |
1666 (defun tcl-reread-help-files () | |
1667 "Set up to re-read files, and then do it." | |
1668 (interactive) | |
1669 (message "Building Tcl help file index...") | |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1670 (setq tcl-help-saved-dirs tcl-help-directory-list) |
6709 | 1671 (setq tcl-help-alist nil) |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1672 (tcl-help-snarf-commands tcl-help-directory-list) |
6709 | 1673 (message "Building Tcl help file index...done")) |
1674 | |
1675 (defun tcl-current-word (flag) | |
1676 "Return current command word, or nil. | |
1677 If FLAG is nil, just uses `current-word'. | |
1678 Otherwise scans backward for most likely Tcl command word." | |
7799
1eb0d0f0f71b
tcl-current-word does the right thing in inferior-tcl-mode.
Tom Tromey <tromey@redhat.com>
parents:
7781
diff
changeset
|
1679 (if (and flag |
1eb0d0f0f71b
tcl-current-word does the right thing in inferior-tcl-mode.
Tom Tromey <tromey@redhat.com>
parents:
7781
diff
changeset
|
1680 (memq major-mode '(tcl-mode inferior-tcl-mode))) |
6709 | 1681 (condition-case nil |
1682 (save-excursion | |
1683 ;; Look backward for first word actually in alist. | |
1684 (if (bobp) | |
1685 () | |
1686 (while (and (not (bobp)) | |
1687 (not (tcl-real-command-p))) | |
1688 (backward-sexp))) | |
1689 (if (assoc (current-word) tcl-help-alist) | |
1690 (current-word))) | |
1691 (error nil)) | |
1692 (current-word))) | |
1693 | |
8252
7d4674a34de3
Added ";;;###autoload" comments where appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7799
diff
changeset
|
1694 ;;;###autoload |
6709 | 1695 (defun tcl-help-on-word (command &optional arg) |
1696 "Get help on Tcl command. Default is word at point. | |
1697 Prefix argument means invert sense of `tcl-use-smart-word-finder'." | |
1698 (interactive | |
1699 (list | |
1700 (progn | |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1701 (if (not (equal tcl-help-directory-list tcl-help-saved-dirs)) |
6709 | 1702 (tcl-reread-help-files)) |
1703 (let ((word (tcl-current-word | |
1704 (if current-prefix-arg | |
1705 (not tcl-use-smart-word-finder) | |
1706 tcl-use-smart-word-finder)))) | |
1707 (completing-read | |
1708 (if (or (null word) (string= word "")) | |
1709 "Help on Tcl command: " | |
1710 (format "Help on Tcl command (default %s): " word)) | |
1711 tcl-help-alist nil t))) | |
1712 current-prefix-arg)) | |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1713 (if (not (equal tcl-help-directory-list tcl-help-saved-dirs)) |
6709 | 1714 (tcl-reread-help-files)) |
1715 (if (string= command "") | |
1716 (setq command (tcl-current-word | |
1717 (if arg | |
1718 (not tcl-use-smart-word-finder) | |
1719 tcl-use-smart-word-finder)))) | |
1720 (let* ((help (get-buffer-create "*Tcl help*")) | |
1721 (cell (assoc command tcl-help-alist)) | |
1722 (file (and cell (cdr cell)))) | |
1723 (set-buffer help) | |
1724 (delete-region (point-min) (point-max)) | |
1725 (if file | |
1726 (progn | |
1727 (insert "*** " command "\n\n") | |
1728 (insert-file-contents file)) | |
1729 (if (string= command "") | |
1730 (insert "Magical Pig!") | |
1731 (insert "Tcl command " command " not in help\n"))) | |
1732 (set-buffer-modified-p nil) | |
1733 (goto-char (point-min)) | |
1734 (display-buffer help))) | |
1735 | |
1736 | |
1737 | |
1738 ;; | |
1739 ;; Other interactive stuff. | |
1740 ;; | |
1741 | |
1742 (defvar tcl-previous-dir/file nil | |
1743 "Record last directory and file used in loading. | |
1744 This holds a cons cell of the form `(DIRECTORY . FILE)' | |
1745 describing the last `tcl-load-file' command.") | |
1746 | |
1747 (defun tcl-load-file (file &optional and-go) | |
1748 "Load a Tcl file into the inferior Tcl process. | |
1749 Prefix argument means switch to the Tcl buffer afterwards." | |
1750 (interactive | |
1751 (list | |
1752 ;; car because comint-get-source returns a list holding the | |
1753 ;; filename. | |
8581
e7daed44da21
tcl-load-file default to current buffer.
Tom Tromey <tromey@redhat.com>
parents:
8580
diff
changeset
|
1754 (car (comint-get-source "Load Tcl file: " |
e7daed44da21
tcl-load-file default to current buffer.
Tom Tromey <tromey@redhat.com>
parents:
8580
diff
changeset
|
1755 (or (and |
e7daed44da21
tcl-load-file default to current buffer.
Tom Tromey <tromey@redhat.com>
parents:
8580
diff
changeset
|
1756 (eq major-mode 'tcl-mode) |
e7daed44da21
tcl-load-file default to current buffer.
Tom Tromey <tromey@redhat.com>
parents:
8580
diff
changeset
|
1757 (buffer-file-name)) |
e7daed44da21
tcl-load-file default to current buffer.
Tom Tromey <tromey@redhat.com>
parents:
8580
diff
changeset
|
1758 tcl-previous-dir/file) |
6709 | 1759 '(tcl-mode) t)) |
1760 current-prefix-arg)) | |
1761 (comint-check-source file) | |
1762 (setq tcl-previous-dir/file (cons (file-name-directory file) | |
1763 (file-name-nondirectory file))) | |
1764 (tcl-send-string (inferior-tcl-proc) | |
1765 (format inferior-tcl-source-command (tcl-quote file))) | |
1766 (if and-go (switch-to-tcl t))) | |
1767 | |
1768 (defun tcl-restart-with-file (file &optional and-go) | |
1769 "Restart inferior Tcl with file. | |
1770 If an inferior Tcl process exists, it is killed first. | |
1771 Prefix argument means switch to the Tcl buffer afterwards." | |
1772 (interactive | |
1773 (list | |
1774 (car (comint-get-source "Restart with Tcl file: " | |
1775 (or (and | |
1776 (eq major-mode 'tcl-mode) | |
1777 (buffer-file-name)) | |
1778 tcl-previous-dir/file) | |
1779 '(tcl-mode) t)) | |
1780 current-prefix-arg)) | |
1781 (let* ((buf (if (eq major-mode 'inferior-tcl-mode) | |
1782 (current-buffer) | |
1783 inferior-tcl-buffer)) | |
1784 (proc (and buf (get-process buf)))) | |
1785 (cond | |
1786 ((not (and buf (get-buffer buf))) | |
1787 ;; I think this will be ok. | |
1788 (inferior-tcl tcl-application) | |
1789 (tcl-load-file file and-go)) | |
1790 ((or | |
1791 (not (comint-check-proc buf)) | |
1792 (yes-or-no-p | |
1793 "A Tcl process is running, are you sure you want to reset it? ")) | |
1794 (save-excursion | |
1795 (comint-check-source file) | |
1796 (setq tcl-previous-dir/file (cons (file-name-directory file) | |
1797 (file-name-nondirectory file))) | |
1798 (comint-exec (get-buffer-create buf) | |
1799 (if proc | |
1800 (process-name proc) | |
1801 "inferior-tcl") | |
1802 tcl-application file tcl-command-switches) | |
1803 (if and-go (switch-to-tcl t))))))) | |
1804 | |
1805 ;; FIXME I imagine you can do this under Emacs 18. I just don't know | |
1806 ;; how. | |
1807 (defun tcl-auto-fill-mode (&optional arg) | |
1808 "Like `auto-fill-mode', but controls filling of Tcl comments." | |
1809 (interactive "P") | |
1810 (and (not tcl-using-emacs-19) | |
1811 (error "You must use Emacs 19 to get this feature.")) | |
1812 ;; Following code taken from "auto-fill-mode" (simple.el). | |
1813 (prog1 | |
1814 (setq auto-fill-function | |
1815 (if (if (null arg) | |
1816 (not auto-fill-function) | |
1817 (> (prefix-numeric-value arg) 0)) | |
1818 'tcl-do-auto-fill | |
1819 nil)) | |
1820 ;; Update mode line. FIXME I'd use force-mode-line-update, but I | |
1821 ;; don't know if it exists in v18. | |
1822 (set-buffer-modified-p (buffer-modified-p)))) | |
1823 | |
1824 (defun tcl-electric-hash (&optional count) | |
1825 "Insert a `#' and quote if it does not start a real comment. | |
1826 Prefix arg is number of `#'s to insert. | |
1827 See variable `tcl-electric-hash-style' for description of quoting | |
1828 styles." | |
1829 (interactive "p") | |
1830 (or count (setq count 1)) | |
1831 (if (> count 0) | |
1832 (let ((type | |
1833 (if (eq tcl-electric-hash-style 'smart) | |
1834 (if (> count 3) ; FIXME what is "smart"? | |
1835 'quote | |
1836 'backslash) | |
1837 tcl-electric-hash-style)) | |
1838 comment) | |
1839 (if type | |
1840 (progn | |
1841 (save-excursion | |
1842 (insert "#") | |
1843 (setq comment (tcl-in-comment))) | |
1844 (delete-char 1) | |
1845 (and tcl-explain-indentation (message "comment: %s" comment)) | |
1846 (cond | |
1847 ((eq type 'quote) | |
1848 (if (not comment) | |
1849 (insert "\""))) | |
1850 ((eq type 'backslash) | |
1851 ;; The following will set count to 0, so the | |
1852 ;; insert-char can still be run. | |
1853 (if (not comment) | |
1854 (while (> count 0) | |
1855 (insert "\\#") | |
1856 (setq count (1- count))))) | |
1857 (t nil)))) | |
1858 (insert-char ?# count)))) | |
1859 | |
1860 (defun tcl-hashify-buffer () | |
1861 "Quote all `#'s in current buffer that aren't Tcl comments." | |
1862 (interactive) | |
1863 (save-excursion | |
1864 (goto-char (point-min)) | |
1865 (if (and tcl-pps-has-arg-6 tcl-use-hairy-comment-detector) | |
1866 (let (state | |
1867 result) | |
1868 (while (< (point) (point-max)) | |
1869 (setq result (tcl-hairy-scan-for-comment state (point-max) t)) | |
1870 (if (car result) | |
1871 (beginning-of-line 2) | |
1872 (backward-char) | |
1873 (if (eq ?# (following-char)) | |
1874 (insert "\\")) | |
1875 (forward-char)) | |
1876 (setq state (cdr result)))) | |
1877 (while (and (< (point) (point-max)) | |
1878 (search-forward "#" nil 'move)) | |
1879 (if (tcl-real-comment-p) | |
1880 (beginning-of-line 2) | |
1881 ;; There's really no good way for the simple converter to | |
1882 ;; work. So we just quote # if it isn't already quoted. | |
1883 ;; Bogus, but it works. | |
1884 (backward-char) | |
1885 (if (not (eq ?\\ (preceding-char))) | |
1886 (insert "\\")) | |
1887 (forward-char)))))) | |
1888 | |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1889 (defun tcl-indent-for-comment () |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1890 "Indent this line's comment to comment column, or insert an empty comment. |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1891 Is smart about syntax of Tcl comments. |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1892 Parts of this were taken from indent-for-comment (simple.el)." |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1893 (interactive "*") |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1894 (end-of-line) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1895 (or (tcl-in-comment) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1896 (progn |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1897 ;; Not in a comment, so we have to insert one. Create an |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1898 ;; empty comment (since there isn't one on this line). If |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1899 ;; line is not blank, make sure we insert a ";" first. |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1900 (skip-chars-backward " \t") |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1901 (let ((eolpoint (point))) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1902 (beginning-of-line) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1903 (if (/= (point) eolpoint) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1904 (progn |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1905 (goto-char eolpoint) |
7628 | 1906 (insert |
1907 (if (tcl-real-command-p) "" ";") | |
1908 "# ") | |
1909 (backward-char)))))) | |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1910 ;; Point is just after the "#" starting a comment. Move it as |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1911 ;; appropriate. |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1912 (let* ((indent (if comment-indent-hook |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1913 (funcall comment-indent-hook) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1914 (funcall comment-indent-function))) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1915 (begpos (progn |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1916 (backward-char) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1917 (point)))) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1918 (if (/= begpos indent) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1919 (progn |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1920 (skip-chars-backward " \t" (save-excursion |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1921 (beginning-of-line) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1922 (point))) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1923 (delete-region (point) begpos) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1924 (indent-to indent))) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1925 (looking-at comment-start-skip) ; Always true. |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1926 (goto-char (match-end 0)) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1927 ;; I don't like the effect of the next two. |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1928 ;;(skip-chars-backward " \t" (match-beginning 0)) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1929 ;;(skip-chars-backward "^ \t" (match-beginning 0)) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1930 )) |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1931 |
6709 | 1932 ;; The following was inspired by the Tcl editing mode written by |
1933 ;; Gregor Schmid <schmid@fb3-s7.math.TU-Berlin.DE>. His version also | |
1934 ;; attempts to snarf the command line options from the command line, | |
1935 ;; but I didn't think that would really be that helpful (doesn't seem | |
1936 ;; like it owould be right enough. His version also looks for the | |
1937 ;; "#!/bin/csh ... exec" hack, but that seemed even less useful. | |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1938 ;; FIXME should make sure that the application mentioned actually |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1939 ;; exists. |
6709 | 1940 (defun tcl-guess-application () |
1941 "Attempt to guess Tcl application by looking at first line. | |
1942 The first line is assumed to look like \"#!.../program ...\"." | |
1943 (save-excursion | |
1944 (goto-char (point-min)) | |
8580
648f78c8ecf5
Fixed bug in tcl-guess-application.
Tom Tromey <tromey@redhat.com>
parents:
8575
diff
changeset
|
1945 (if (looking-at "#![^ \t]*/\\([^ \t\n/]+\\)\\([ \t]\\|$\\)") |
6709 | 1946 (progn |
1947 (make-local-variable 'tcl-application) | |
1948 (setq tcl-application (buffer-substring (match-beginning 1) | |
1949 (match-end 1))))))) | |
1950 | |
1951 ;; This only exists to put on the menubar. I couldn't figure out any | |
1952 ;; other way to do it. FIXME should take "number of #-marks" | |
1953 ;; argument. | |
1954 (defun tcl-uncomment-region (beg end) | |
1955 "Uncomment region." | |
1956 (interactive "r") | |
1957 (comment-region beg end -1)) | |
1958 | |
1959 | |
1960 | |
1961 ;; | |
1962 ;; Lucid menu support. | |
1963 ;; Taken from schmid@fb3-s7.math.TU-Berlin.DE (Gregor Schmid), | |
1964 ;; who wrote a different Tcl mode. | |
7612 | 1965 ;; We also have support for menus in FSF. We do this by |
6709 | 1966 ;; loading the Lucid menu emulation code. |
1967 ;; | |
1968 | |
1969 (defun tcl-popup-menu (e) | |
7612 | 1970 (interactive "@e") |
6709 | 1971 (and tcl-using-emacs-19 |
1972 (not tcl-using-lemacs-19) | |
8339
b6e4f16c969a
Emacs 18 changes from Carl Witty.
Tom Tromey <tromey@redhat.com>
parents:
8252
diff
changeset
|
1973 (if tcl-using-emacs-19-23 |
6711
f464d8689cb3
Bug fix; 19.23 should (require 'lmenu).
Tom Tromey <tromey@redhat.com>
parents:
6710
diff
changeset
|
1974 (require 'lmenu) |
6709 | 1975 ;; CAVEATS: |
1976 ;; * lmenu.el provides 'menubar, which is bogus. | |
1977 ;; * lmenu.el causes menubars to be turned on everywhere. | |
1978 ;; Doubly bogus! | |
1979 ;; Both of these problems are fixed in Emacs 19.23. People | |
1980 ;; using an Emacs before that just suffer. | |
1981 (require 'menubar "lmenu"))) ;; This is annoying | |
7612 | 1982 ;; IMHO popup-menu should be autoloaded in FSF Emacs. Oh well. |
6709 | 1983 (popup-menu tcl-lucid-menu)) |
1984 | |
1985 | |
1986 | |
1987 ;; | |
1988 ;; Quoting and unquoting functions. | |
1989 ;; | |
1990 | |
1991 ;; This quoting is sufficient to protect eg a filename from any sort | |
1992 ;; of expansion or splitting. Tcl quoting sure sucks. | |
1993 (defun tcl-quote (string) | |
1994 "Quote STRING according to Tcl rules." | |
1995 (mapconcat (function (lambda (char) | |
1996 (if (memq char '(?[ ?] ?{ ?} ?\\ ?\" ?$ ? ?\;)) | |
1997 (concat "\\" (char-to-string char)) | |
1998 (char-to-string char)))) | |
1999 string "")) | |
2000 | |
2001 | |
2002 | |
7628 | 2003 ;; |
2004 ;; Bug reporting. | |
2005 ;; | |
2006 | |
2007 (and (fboundp 'eval-when-compile) | |
2008 (eval-when-compile | |
2009 (require 'reporter))) | |
2010 | |
2011 (defun tcl-submit-bug-report () | |
2012 "Submit via mail a bug report on Tcl mode." | |
2013 (interactive) | |
2014 (require 'reporter) | |
2015 (and | |
2016 (y-or-n-p "Do you really want to submit a bug report on Tcl mode? ") | |
2017 (reporter-submit-bug-report | |
2018 tcl-maintainer | |
2019 (concat "Tcl mode " tcl-version) | |
2020 '(tcl-indent-level | |
2021 tcl-continued-indent-level | |
2022 tcl-auto-newline | |
2023 tcl-tab-always-indent | |
2024 tcl-use-hairy-comment-detector | |
7771
f23eaf6babac
Fixed bug in bug-reporting code.
Tom Tromey <tromey@redhat.com>
parents:
7687
diff
changeset
|
2025 tcl-electric-hash-style |
7628 | 2026 tcl-help-directory-list |
2027 tcl-use-smart-word-finder | |
2028 tcl-application | |
2029 tcl-command-switches | |
2030 tcl-prompt-regexp | |
2031 inferior-tcl-source-command | |
2032 tcl-using-emacs-19 | |
8339
b6e4f16c969a
Emacs 18 changes from Carl Witty.
Tom Tromey <tromey@redhat.com>
parents:
8252
diff
changeset
|
2033 tcl-using-emacs-19-23 |
7628 | 2034 tcl-using-lemacs-19 |
2035 tcl-proc-list | |
2036 tcl-proc-regexp | |
2037 tcl-typeword-list | |
2038 tcl-keyword-list | |
2039 tcl-font-lock-keywords | |
2040 tcl-pps-has-arg-6)))) | |
2041 | |
2042 | |
2043 | |
6709 | 2044 (provide 'tcl) |
2045 | |
2046 ;;; tcl.el ends here |