Mercurial > emacs
annotate lisp/progmodes/tcl.el @ 110977:a5cd85a6290e
Define a cursor defface; minor face optimizations.
* faces.el (face-spec-reset-face): Reset all attributes in one
single call to set-face-attribute.
(face-spec-match-p): Make it a defsubst.
(frame-set-background-mode): New arg KEEP-FACE-SPECS.
(x-create-frame-with-faces, tty-create-frame-with-faces)
(tty-set-up-initial-frame-faces): Don't recompute face specs in
frame-set-background-mode, since they are recomputed immediately
afterwards in face-set-after-frame-default.
(face-set-after-frame-default): Minor optimization.
(cursor): Provide non-trivial defface spec.
* custom.el (custom-theme-recalc-face): Simplify.
author | Chong Yidong <cyd@stupidchicken.com> |
---|---|
date | Wed, 13 Oct 2010 23:55:18 -0400 |
parents | b10051866f51 |
children | 56b71cddc9c5 |
rev | line source |
---|---|
38436
b174db545cfd
Some fixes to follow coding conventions.
Pavel Janík <Pavel@Janik.cz>
parents:
35712
diff
changeset
|
1 ;;; tcl.el --- Tcl code editing commands for Emacs |
6709 | 2 |
100908 | 3 ;; Copyright (C) 1994, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, |
106815 | 4 ;; 2006, 2007, 2008, 2009, 2010 Free Software Foundation, Inc. |
6709 | 5 |
44320
40a69f39b79f
Change maintainer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44316
diff
changeset
|
6 ;; Maintainer: FSF |
43437
55d255989f05
(tcl-do-fill-paragraph): Find and fill on more
Richard M. Stallman <rms@gnu.org>
parents:
39754
diff
changeset
|
7 ;; Author: Tom Tromey <tromey@redhat.com> |
6710
85f4c4971597
Fixed up headers for release.
Tom Tromey <tromey@redhat.com>
parents:
6709
diff
changeset
|
8 ;; Chris Lindblad <cjl@lcs.mit.edu> |
85f4c4971597
Fixed up headers for release.
Tom Tromey <tromey@redhat.com>
parents:
6709
diff
changeset
|
9 ;; Keywords: languages tcl modes |
6709 | 10 |
11 ;; This file is part of GNU Emacs. | |
12 | |
94673
52b7a8c22af5
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
79717
diff
changeset
|
13 ;; GNU Emacs is free software: you can redistribute it and/or modify |
6709 | 14 ;; it under the terms of the GNU General Public License as published by |
94673
52b7a8c22af5
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
79717
diff
changeset
|
15 ;; the Free Software Foundation, either version 3 of the License, or |
52b7a8c22af5
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
79717
diff
changeset
|
16 ;; (at your option) any later version. |
6709 | 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 | |
94673
52b7a8c22af5
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
79717
diff
changeset
|
24 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. |
6709 | 25 |
25163 | 26 ;; BEFORE USE: |
6709 | 27 ;; |
28 ;; 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
|
29 ;; 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
|
30 ;; directories containing the TclX help files. Eg: |
6709 | 31 ;; |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
32 ;; (setq tcl-help-directory-list '("/usr/local/lib/tclx/help")) |
6709 | 33 ;; |
34 ;;; Commentary: | |
35 | |
36 ;; CUSTOMIZATION NOTES: | |
37 ;; * tcl-proc-list can be used to customize a list of things that | |
38 ;; "define" other things. Eg in my project I put "defvar" in this | |
39 ;; list. | |
40 ;; * tcl-typeword-list is similar, but uses font-lock-type-face. | |
41 ;; * tcl-keyword-list is a list of keywords. I've generally used this | |
42 ;; for flow-control words. Eg I add "unwind_protect" to this list. | |
61314
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
43 ;; * tcl-builtin-list lists commands to be given font-lock-builtin-face. |
6709 | 44 ;; * tcl-type-alist can be used to minimally customize indentation |
45 ;; according to context. | |
46 | |
25176 | 47 ;; THANKS FOR CRITICISM AND SUGGESTIONS TO: |
6709 | 48 ;; Guido Bosch <Guido.Bosch@loria.fr> |
49 ;; pgs1002@esc.cam.ac.uk (Dr P.G. Sjoerdsma) | |
50 ;; Mike Scheidler <c23mts@kocrsv01.delcoelect.com> | |
51 ;; Matt Newman <men@charney.colorado.edu> | |
52 ;; rwhitby@research.canon.oz.au (Rod Whitby) | |
53 ;; h9118101@hkuxa.hku.hk (Yip Chi Lap [Beta]) | |
54 ;; Pertti Tapio Kasanen <ptk@delta.hut.fi> | |
55 ;; 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
|
56 ;; warsaw@nlm.nih.gov (Barry A. Warsaw) |
b6e4f16c969a
Emacs 18 changes from Carl Witty.
Tom Tromey <tromey@redhat.com>
parents:
8252
diff
changeset
|
57 ;; Carl Witty <cwitty@ai.mit.edu> |
8580
648f78c8ecf5
Fixed bug in tcl-guess-application.
Tom Tromey <tromey@redhat.com>
parents:
8575
diff
changeset
|
58 ;; T. V. Raman <raman@crl.dec.com> |
11303
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
59 ;; Jesper Pedersen <blackie@imada.ou.dk> |
11787
635f5fb5d82a
Changed "Lucid Emacs" to "XEmacs".
Tom Tromey <tromey@redhat.com>
parents:
11303
diff
changeset
|
60 ;; dfarmer@evolving.com (Doug Farmer) |
12924
8172973fd6e4
(tcl-hilit): New function from "Chris Alfeld" <calfeld@math.utah.edu>
Tom Tromey <tromey@redhat.com>
parents:
12795
diff
changeset
|
61 ;; "Chris Alfeld" <calfeld@math.utah.edu> |
44320
40a69f39b79f
Change maintainer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44316
diff
changeset
|
62 ;; Ben Wing <ben@xemacs.org> |
6709 | 63 |
64 ;; KNOWN BUGS: | |
44320
40a69f39b79f
Change maintainer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44316
diff
changeset
|
65 ;; * In Tcl "#" is not always a comment character. This can confuse tcl.el |
40a69f39b79f
Change maintainer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44316
diff
changeset
|
66 ;; in certain circumstances. For now the only workaround is to use |
40a69f39b79f
Change maintainer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44316
diff
changeset
|
67 ;; font-lock which will mark the # chars accordingly or enclose offending |
40a69f39b79f
Change maintainer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44316
diff
changeset
|
68 ;; hash characters in quotes or precede them with a backslash. Note that |
40a69f39b79f
Change maintainer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44316
diff
changeset
|
69 ;; using braces won't work -- quotes change the syntax class of characters |
40a69f39b79f
Change maintainer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44316
diff
changeset
|
70 ;; between them, while braces do not. If you don't use font-lock, the |
40a69f39b79f
Change maintainer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44316
diff
changeset
|
71 ;; electric-# mode helps alleviate this problem somewhat. |
6709 | 72 ;; * indent-tcl-exp is untested. |
73 | |
74 ;; TODO: | |
75 ;; * make add-log-tcl-defun smarter. should notice if we are in the | |
76 ;; middle of a defun, or between defuns. should notice if point is | |
77 ;; on first line of defun (or maybe even in comments before defun). | |
78 ;; * Allow continuation lines to be indented under the first argument | |
44227
a1c4f9151348
(tcl-imenu-create-index-function): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
43437
diff
changeset
|
79 ;; of the preceding line, like this: |
6709 | 80 ;; [list something \ |
81 ;; something-else] | |
82 ;; * There is a request that indentation work like this: | |
83 ;; button .fred -label Fred \ | |
84 ;; -command {puts fred} | |
85 ;; * Should have tcl-complete-symbol that queries the inferior process. | |
86 ;; * Should have describe-symbol that works by sending the magic | |
87 ;; command to a tclX process. | |
88 ;; * Need C-x C-e binding (tcl-eval-last-exp). | |
89 ;; * Write indent-region function that is faster than indenting each | |
90 ;; line individually. | |
91 ;; * tcl-figure-type should stop at "beginning of line" (only ws | |
92 ;; before point, and no "\" on previous line). (see tcl-real-command-p). | |
93 ;; * overrides some comint keybindings; fix. | |
94 ;; * Trailing \ will eat blank lines. Should deal with this. | |
95 ;; (this would help catch some potential bugs). | |
96 ;; * 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
|
97 ;; * Indentation should deal with "switch". |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
98 ;; * Consider writing code to find help files automatically (for |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
99 ;; common cases). |
7628 | 100 ;; * `#' shouldn't insert `\#' when point is in string. |
6709 | 101 |
102 | |
103 | |
104 ;;; Code: | |
105 | |
35712
350ba5553ea3
(outline, dabbrev, add-log): Require when
Gerd Moellmann <gerd@gnu.org>
parents:
29408
diff
changeset
|
106 (eval-when-compile |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
107 (require 'imenu) |
35712
350ba5553ea3
(outline, dabbrev, add-log): Require when
Gerd Moellmann <gerd@gnu.org>
parents:
29408
diff
changeset
|
108 (require 'outline) |
350ba5553ea3
(outline, dabbrev, add-log): Require when
Gerd Moellmann <gerd@gnu.org>
parents:
29408
diff
changeset
|
109 (require 'dabbrev) |
350ba5553ea3
(outline, dabbrev, add-log): Require when
Gerd Moellmann <gerd@gnu.org>
parents:
29408
diff
changeset
|
110 (require 'add-log)) |
350ba5553ea3
(outline, dabbrev, add-log): Require when
Gerd Moellmann <gerd@gnu.org>
parents:
29408
diff
changeset
|
111 |
6709 | 112 (require 'comint) |
113 | |
114 ;; | |
115 ;; User variables. | |
116 ;; | |
117 | |
25176 | 118 (defgroup tcl nil |
64053
fd24f2ae0e10
(tcl): Finish `defgroup' description with period.
Juanma Barranquero <lekktu@gmail.com>
parents:
62531
diff
changeset
|
119 "Major mode for editing Tcl source in Emacs." |
66963
a11fdee52c05
Add :link (custom-group-link font-lock-faces) to defgroup.
Juri Linkov <juri@jurta.org>
parents:
64085
diff
changeset
|
120 :link '(custom-group-link :tag "Font Lock Faces group" font-lock-faces) |
25176 | 121 :group 'languages) |
122 | |
123 (defcustom tcl-indent-level 4 | |
124 "*Indentation of Tcl statements with respect to containing block." | |
62531
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
125 :type 'integer |
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
126 :group 'tcl) |
78458
ab02dcd8b2b4
(tcl-indent-level, tcl-continued-indent-level): Add safe-local-variable prop.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78234
diff
changeset
|
127 (put 'tcl-indent-level 'safe-local-variable 'integerp) |
6709 | 128 |
25176 | 129 (defcustom tcl-continued-indent-level 4 |
130 "*Indentation of continuation line relative to first line of command." | |
62531
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
131 :type 'integer |
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
132 :group 'tcl) |
78458
ab02dcd8b2b4
(tcl-indent-level, tcl-continued-indent-level): Add safe-local-variable prop.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
78234
diff
changeset
|
133 (put 'tcl-continued-indent-level 'safe-local-variable 'integerp) |
6709 | 134 |
25176 | 135 (defcustom tcl-auto-newline nil |
136 "*Non-nil means automatically newline before and after braces you insert." | |
62531
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
137 :type 'boolean |
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
138 :group 'tcl) |
6709 | 139 |
51056
5dbeffb17d8e
(tcl-indent-exp): Remove dead code.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
50856
diff
changeset
|
140 (defcustom tcl-tab-always-indent tab-always-indent |
6709 | 141 "*Control effect of TAB key. |
142 If t (the default), always indent current line. | |
143 If nil and point is not in the indentation area at the beginning of | |
144 the line, a TAB is inserted. | |
145 Other values cause the first possible action from the following list | |
146 to take place: | |
147 | |
148 1. Move from beginning of line to correct indentation. | |
149 2. Delete an empty comment. | |
150 3. Move forward to start of comment, indenting if necessary. | |
151 4. Move forward to end of line, indenting if necessary. | |
152 5. Create an empty comment. | |
25176 | 153 6. Move backward to start of comment, indenting if necessary." |
154 :type '(choice (const :tag "Always" t) | |
155 (const :tag "Beginning only" nil) | |
62531
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
156 (const :tag "Maybe move or make or delete comment" 'tcl)) |
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
157 :group 'tcl) |
25176 | 158 |
6709 | 159 |
44320
40a69f39b79f
Change maintainer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44316
diff
changeset
|
160 (defcustom tcl-electric-hash-style nil ;; 'smart |
6709 | 161 "*Style of electric hash insertion to use. |
25163 | 162 Possible values are `backslash', meaning that `\\' quoting should be |
163 done; `quote', meaning that `\"' quoting should be done; `smart', | |
164 meaning that the choice between `backslash' and `quote' should be | |
6709 | 165 made depending on the number of hashes inserted; or nil, meaning that |
166 no quoting should be done. Any other value for this variable is | |
44320
40a69f39b79f
Change maintainer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44316
diff
changeset
|
167 taken to mean `smart'. The default is nil." |
62531
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
168 :type '(choice (const backslash) (const quote) (const smart) (const nil)) |
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
169 :group 'tcl) |
6709 | 170 |
25176 | 171 (defcustom tcl-help-directory-list nil |
172 "*List of topmost directories containing TclX help files." | |
62531
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
173 :type '(repeat directory) |
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
174 :group 'tcl) |
6709 | 175 |
25176 | 176 (defcustom tcl-use-smart-word-finder t |
177 "*If not nil, use smart way to find current word, for Tcl help feature." | |
62531
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
178 :type 'boolean |
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
179 :group 'tcl) |
6709 | 180 |
25176 | 181 (defcustom tcl-application "wish" |
182 "*Name of Tcl program to run in inferior Tcl mode." | |
62531
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
183 :type 'string |
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
184 :group 'tcl) |
6709 | 185 |
25176 | 186 (defcustom tcl-command-switches nil |
187 "*List of switches to supply to the `tcl-application' program." | |
62531
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
188 :type '(repeat string) |
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
189 :group 'tcl) |
25176 | 190 |
191 (defcustom tcl-prompt-regexp "^\\(% \\|\\)" | |
6709 | 192 "*If not nil, a regexp that will match the prompt in the inferior process. |
193 If nil, the prompt is the name of the application with \">\" appended. | |
194 | |
195 The default is \"^\\(% \\|\\)\", which will match the default primary | |
25176 | 196 and secondary prompts for tclsh and wish." |
62531
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
197 :type 'regexp |
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
198 :group 'tcl) |
6709 | 199 |
25176 | 200 (defcustom inferior-tcl-source-command "source %s\n" |
6709 | 201 "*Format-string for building a Tcl command to load a file. |
202 This format string should use `%s' to substitute a file name | |
203 and should result in a Tcl expression that will command the | |
204 inferior Tcl to load that file. The filename will be appropriately | |
25176 | 205 quoted for Tcl." |
62531
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
206 :type 'string |
c905fcf5e3d9
Specify missing group (and type, if simple) in defcustom.
Juanma Barranquero <lekktu@gmail.com>
parents:
61314
diff
changeset
|
207 :group 'tcl) |
6709 | 208 |
61314
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
209 (defface tcl-escaped-newline '((t :inherit font-lock-string-face)) |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
210 "Face used for (non-escaped) backslash at end of a line in Tcl mode." |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
211 :group 'tcl |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
212 :version "22.1") |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
213 |
6709 | 214 ;; |
215 ;; Keymaps, abbrevs, syntax tables. | |
216 ;; | |
217 | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
218 (defvar tcl-mode-map |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
219 (let ((map (make-sparse-keymap))) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
220 (define-key map "{" 'tcl-electric-char) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
221 (define-key map "}" 'tcl-electric-brace) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
222 (define-key map "[" 'tcl-electric-char) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
223 (define-key map "]" 'tcl-electric-char) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
224 (define-key map ";" 'tcl-electric-char) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
225 (define-key map "#" 'tcl-electric-hash) ;Remove? -stef |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
226 (define-key map "\e\C-q" 'tcl-indent-exp) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
227 (define-key map "\177" 'backward-delete-char-untabify) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
228 (define-key map "\t" 'tcl-indent-command) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
229 (define-key map "\M-\C-x" 'tcl-eval-defun) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
230 (define-key map "\C-c\C-i" 'tcl-help-on-word) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
231 (define-key map "\C-c\C-v" 'tcl-eval-defun) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
232 (define-key map "\C-c\C-f" 'tcl-load-file) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
233 (define-key map "\C-c\C-t" 'inferior-tcl) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
234 (define-key map "\C-c\C-x" 'tcl-eval-region) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
235 (define-key map "\C-c\C-s" 'switch-to-tcl) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
236 map) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
237 "Keymap used in `tcl-mode'.") |
6709 | 238 |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
239 (defvar tcl-mode-syntax-table |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
240 (let ((st (make-syntax-table))) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
241 (modify-syntax-entry ?% "_" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
242 (modify-syntax-entry ?@ "_" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
243 (modify-syntax-entry ?& "_" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
244 (modify-syntax-entry ?* "_" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
245 (modify-syntax-entry ?+ "_" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
246 (modify-syntax-entry ?- "_" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
247 (modify-syntax-entry ?. "_" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
248 (modify-syntax-entry ?: "_" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
249 (modify-syntax-entry ?! "_" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
250 (modify-syntax-entry ?$ "_" st) ; FIXME use "'"? |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
251 (modify-syntax-entry ?/ "_" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
252 (modify-syntax-entry ?~ "_" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
253 (modify-syntax-entry ?< "_" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
254 (modify-syntax-entry ?= "_" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
255 (modify-syntax-entry ?> "_" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
256 (modify-syntax-entry ?| "_" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
257 (modify-syntax-entry ?\( "()" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
258 (modify-syntax-entry ?\) ")(" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
259 (modify-syntax-entry ?\; "." st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
260 (modify-syntax-entry ?\n ">" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
261 ;; (modify-syntax-entry ?\f ">" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
262 (modify-syntax-entry ?# "<" st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
263 st) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
264 "Syntax table in use in `tcl-mode' buffers.") |
6709 | 265 |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
266 (defvar inferior-tcl-mode-map |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
267 ;; FIXME we override comint keybindings here. |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
268 ;; Maybe someone has a better set? |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
269 (let ((map (make-sparse-keymap))) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
270 ;; Will inherit from `comint-mode-map' thanks to define-derived-mode. |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
271 (define-key map "\t" 'comint-dynamic-complete) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
272 (define-key map "\M-?" 'comint-dynamic-list-filename-completions) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
273 (define-key map "\177" 'backward-delete-char-untabify) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
274 (define-key map "\M-\C-x" 'tcl-eval-defun) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
275 (define-key map "\C-c\C-i" 'tcl-help-on-word) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
276 (define-key map "\C-c\C-v" 'tcl-eval-defun) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
277 (define-key map "\C-c\C-f" 'tcl-load-file) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
278 (define-key map "\C-c\C-t" 'inferior-tcl) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
279 (define-key map "\C-c\C-x" 'tcl-eval-region) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
280 (define-key map "\C-c\C-s" 'switch-to-tcl) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
281 map) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
282 "Keymap used in `inferior-tcl-mode'.") |
6709 | 283 |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
284 (easy-menu-define tcl-mode-menu tcl-mode-map "Menu used in `tcl-mode'." |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
285 '("Tcl" |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
286 ["Beginning of function" beginning-of-defun t] |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
287 ["End of function" end-of-defun t] |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
288 ["Mark function" mark-defun t] |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
289 ["Indent region" indent-region (mark t)] |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
290 ["Comment region" comment-region (mark t)] |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
291 ["Uncomment region" uncomment-region (mark t)] |
6709 | 292 "----" |
293 ["Show Tcl process buffer" inferior-tcl t] | |
7687
6447f9b3c966
Menu items now sensitive as appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7635
diff
changeset
|
294 ["Send function to Tcl process" tcl-eval-defun |
7781 | 295 (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
|
296 ["Send region to Tcl process" tcl-eval-region |
7781 | 297 (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
|
298 ["Send file to Tcl process" tcl-load-file |
7781 | 299 (and inferior-tcl-buffer (get-buffer inferior-tcl-buffer))] |
6709 | 300 ["Restart Tcl process with file" tcl-restart-with-file t] |
301 "----" | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
302 ["Tcl help" tcl-help-on-word tcl-help-directory-list])) |
6709 | 303 |
304 (defvar inferior-tcl-buffer nil | |
305 "*The current inferior-tcl process buffer. | |
306 | |
307 MULTIPLE PROCESS SUPPORT | |
308 =========================================================================== | |
309 To run multiple Tcl processes, you start the first up with | |
310 \\[inferior-tcl]. It will be in a buffer named `*inferior-tcl*'. | |
311 Rename this buffer with \\[rename-buffer]. You may now start up a new | |
312 process with another \\[inferior-tcl]. It will be in a new buffer, | |
313 named `*inferior-tcl*'. You can switch between the different process | |
314 buffers with \\[switch-to-buffer]. | |
315 | |
316 Commands that send text from source buffers to Tcl processes -- like | |
317 `tcl-eval-defun' or `tcl-load-file' -- have to choose a process to | |
318 send to, when you have more than one Tcl process around. This is | |
319 determined by the global variable `inferior-tcl-buffer'. Suppose you | |
320 have three inferior Lisps running: | |
321 Buffer Process | |
322 foo inferior-tcl | |
323 bar inferior-tcl<2> | |
324 *inferior-tcl* inferior-tcl<3> | |
325 If you do a \\[tcl-eval-defun] command on some Lisp source code, what | |
326 process do you send it to? | |
327 | |
49598
0d8b17d428b5
Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48192
diff
changeset
|
328 - If you're in a process buffer (foo, bar, or *inferior-tcl*), |
6709 | 329 you send it to that process. |
330 - If you're in some other buffer (e.g., a source file), you | |
331 send it to the process attached to buffer `inferior-tcl-buffer'. | |
332 This process selection is performed by function `inferior-tcl-proc'. | |
333 | |
334 Whenever \\[inferior-tcl] fires up a new process, it resets | |
335 `inferior-tcl-buffer' to be the new process's buffer. If you only run | |
336 one process, this does the right thing. If you run multiple | |
337 processes, you can change `inferior-tcl-buffer' to another process | |
338 buffer with \\[set-variable].") | |
339 | |
340 ;; | |
341 ;; Hooks and other customization. | |
342 ;; | |
343 | |
344 (defvar tcl-mode-hook nil | |
345 "Hook run on entry to Tcl mode. | |
346 | |
347 Several functions exist which are useful to run from your | |
348 `tcl-mode-hook' (see each function's documentation for more | |
349 information): | |
350 | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
351 `tcl-guess-application' |
6709 | 352 Guesses a default setting for `tcl-application' based on any |
353 \"#!\" line at the top of the file. | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
354 `tcl-hashify-buffer' |
6709 | 355 Quotes all \"#\" characters that don't correspond to actual |
356 Tcl comments. (Useful when editing code not originally created | |
357 with this mode). | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
358 `tcl-auto-fill-mode' |
6709 | 359 Auto-filling of Tcl comments. |
360 | |
25163 | 361 Add functions to the hook with `add-hook': |
6709 | 362 |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
363 (add-hook 'tcl-mode-hook 'tcl-guess-application)") |
6709 | 364 |
365 | |
366 (defvar tcl-proc-list | |
24954
503bd9d97ac4
(tcl-proc-list): Reverted; already had `body'.
Tom Tromey <tromey@redhat.com>
parents:
24953
diff
changeset
|
367 '("proc" "method" "itcl_class" "body" "configbody" "class") |
6709 | 368 "List of commands whose first argument defines something. |
25163 | 369 This exists because some people (eg, me) use `defvar' et al. |
6709 | 370 Call `tcl-set-proc-regexp' and `tcl-set-font-lock-keywords' |
371 after changing this list.") | |
372 | |
373 (defvar tcl-proc-regexp nil | |
374 "Regexp to use when matching proc headers.") | |
375 | |
376 (defvar tcl-typeword-list | |
22662 | 377 '("global" "upvar" "inherit" "public" "protected" "private" |
24957
e26249ed0833
(tcl-typeword-list): Added `variable'.
Tom Tromey <tromey@redhat.com>
parents:
24956
diff
changeset
|
378 "common" "itk_option" "variable") |
7612 | 379 "List of Tcl keywords denoting \"type\". Used only for highlighting. |
6709 | 380 Call `tcl-set-font-lock-keywords' after changing this list.") |
381 | |
382 ;; Generally I've picked control operators to be keywords. | |
383 (defvar tcl-keyword-list | |
384 '("if" "then" "else" "elseif" "for" "foreach" "break" "continue" "while" | |
385 "eval" "case" "in" "switch" "default" "exit" "error" "proc" "return" | |
12403
f863ead116f0
(tcl-set-proc-regexp): Allow leading spaces.
Tom Tromey <tromey@redhat.com>
parents:
11793
diff
changeset
|
386 "uplevel" "constructor" "destructor" "itcl_class" "loop" "for_array_keys" |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
387 "for_recursive_glob" "for_file" "method" "body" "configbody" "class" |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
388 "chain") |
6709 | 389 "List of Tcl keywords. Used only for highlighting. |
390 Default list includes some TclX keywords. | |
391 Call `tcl-set-font-lock-keywords' after changing this list.") | |
392 | |
61314
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
393 (defvar tcl-builtin-list |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
394 '("after" "append" "array" "bgerror" "binary" "catch" "cd" "clock" |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
395 "close" "concat" "console" "dde" "encoding" "eof" "exec" "expr" |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
396 "fblocked" "fconfigure" "fcopy" "file" "fileevent" "flush" |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
397 "format" "gets" "glob" "history" "incr" "info" "interp" "join" |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
398 "lappend" "lindex" "linsert" "list" "llength" "load" "lrange" |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
399 "lreplace" "lsort" "namespace" "open" "package" "pid" "puts" "pwd" |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
400 "read" "regexp" "registry" "regsub" "rename" "scan" "seek" "set" |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
401 "socket" "source" "split" "string" "subst" "tell" "time" "trace" |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
402 "unknown" "unset" "vwait") |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
403 "List of Tcl commands. Used only for highlighting. |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
404 Call `tcl-set-font-lock-keywords' after changing this list. |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
405 This list excludes those commands already found in `tcl-proc-list' and |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
406 `tcl-keyword-list'.") |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
407 |
6709 | 408 (defvar tcl-font-lock-keywords nil |
409 "Keywords to highlight for Tcl. See variable `font-lock-keywords'. | |
410 This variable is generally set from `tcl-proc-regexp', | |
411 `tcl-typeword-list', and `tcl-keyword-list' by the function | |
412 `tcl-set-font-lock-keywords'.") | |
413 | |
110305
b10051866f51
New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109561
diff
changeset
|
414 (defconst tcl-syntax-propertize-function |
b10051866f51
New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109561
diff
changeset
|
415 (syntax-propertize-rules |
b10051866f51
New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109561
diff
changeset
|
416 ;; Mark the few `#' that are not comment-markers. |
b10051866f51
New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109561
diff
changeset
|
417 ("[^;[{ \t\n][ \t]*\\(#\\)" (1 "."))) |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
418 "Syntactic keywords for `tcl-mode'.") |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
419 |
6709 | 420 ;; FIXME need some way to recognize variables because array refs look |
421 ;; like 2 sexps. | |
422 (defvar tcl-type-alist | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
423 '(("proc" nil tcl-expr tcl-commands) |
12404 | 424 ("method" nil tcl-expr tcl-commands) |
12405
abcf4791a9b0
(tcl-type-alist): More itcl changes.
Tom Tromey <tromey@redhat.com>
parents:
12404
diff
changeset
|
425 ("destructor" tcl-commands) |
abcf4791a9b0
(tcl-type-alist): More itcl changes.
Tom Tromey <tromey@redhat.com>
parents:
12404
diff
changeset
|
426 ("constructor" tcl-commands) |
6709 | 427 ("expr" tcl-expr) |
428 ("catch" tcl-commands) | |
429 ("if" tcl-expr "then" tcl-commands) | |
430 ("elseif" tcl-expr "then" tcl-commands) | |
431 ("elseif" tcl-expr tcl-commands) | |
432 ("if" tcl-expr tcl-commands) | |
433 ("while" tcl-expr tcl-commands) | |
434 ("for" tcl-commands tcl-expr tcl-commands tcl-commands) | |
435 ("foreach" nil nil tcl-commands) | |
436 ("for_file" nil nil tcl-commands) | |
437 ("for_array_keys" nil nil tcl-commands) | |
438 ("for_recursive_glob" nil nil nil tcl-commands) | |
439 ;; Loop handling is not perfect, because the third argument can be | |
440 ;; either a command or an expr, and there is no real way to look | |
441 ;; forward. | |
442 ("loop" nil tcl-expr tcl-expr tcl-commands) | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
443 ("loop" nil tcl-expr tcl-commands)) |
6709 | 444 "Alist that controls indentation. |
445 \(Actually, this really only controls what happens on continuation lines). | |
446 Each entry looks like `(KEYWORD TYPE ...)'. | |
447 Each type entry describes a sexp after the keyword, and can be one of: | |
448 * nil, meaning that this sexp has no particular type. | |
449 * tcl-expr, meaning that this sexp is an arithmetic expression. | |
450 * tcl-commands, meaning that this sexp holds Tcl commands. | |
451 * a string, which must exactly match the string at the corresponding | |
452 position for a match to be made. | |
453 | |
454 For example, the entry for the \"loop\" command is: | |
455 | |
456 (\"loop\" nil tcl-expr tcl-commands) | |
457 | |
458 This means that the \"loop\" command has three arguments. The first | |
459 argument is ignored (for indentation purposes). The second argument | |
460 is a Tcl expression, and the last argument is Tcl commands.") | |
461 | |
462 (defvar tcl-explain-indentation nil | |
50856
2aec3e4bf957
(tcl-explain-indentation): Don't quote nil and t in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
49730
diff
changeset
|
463 "If non-nil, debugging message will be printed during indentation.") |
6709 | 464 |
465 | |
466 | |
49730
ce81e48eab6e
(tcl-omit-ws-regexp): Correctly handle cases like `proc foo {a {b c} d} {'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49598
diff
changeset
|
467 ;; Here's another stab. I think this one actually works. |
ce81e48eab6e
(tcl-omit-ws-regexp): Correctly handle cases like `proc foo {a {b c} d} {'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49598
diff
changeset
|
468 ;; We have to be careful that the open-brace following this regexp |
ce81e48eab6e
(tcl-omit-ws-regexp): Correctly handle cases like `proc foo {a {b c} d} {'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49598
diff
changeset
|
469 ;; is indeed the one corresponding to the function's body so |
ce81e48eab6e
(tcl-omit-ws-regexp): Correctly handle cases like `proc foo {a {b c} d} {'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49598
diff
changeset
|
470 ;; that end-of-defun works correctly. Tricky cases are: |
ce81e48eab6e
(tcl-omit-ws-regexp): Correctly handle cases like `proc foo {a {b c} d} {'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49598
diff
changeset
|
471 ;; proc foo { {arg1 def} arg2 } { |
ce81e48eab6e
(tcl-omit-ws-regexp): Correctly handle cases like `proc foo {a {b c} d} {'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49598
diff
changeset
|
472 ;; as well as |
ce81e48eab6e
(tcl-omit-ws-regexp): Correctly handle cases like `proc foo {a {b c} d} {'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49598
diff
changeset
|
473 ;; proc foo { \n {arg1 def} \n arg2 } { |
ce81e48eab6e
(tcl-omit-ws-regexp): Correctly handle cases like `proc foo {a {b c} d} {'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49598
diff
changeset
|
474 ;; The current setting handles the first case properly but not the second. |
ce81e48eab6e
(tcl-omit-ws-regexp): Correctly handle cases like `proc foo {a {b c} d} {'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49598
diff
changeset
|
475 ;; It also fails if `proc' is not in column-0 (e.g. it's in a namespace). |
58563
72c3587cd01b
(tcl-omit-ws-regexp): Avoid the case where { or [ appears within a comment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58562
diff
changeset
|
476 (defconst tcl-omit-ws-regexp "^[^]\" \t\n#}][^\n\"#]+[ \t]+") |
6709 | 477 |
478 | |
479 | |
480 ;; | |
481 ;; Some helper functions. | |
482 ;; | |
483 | |
484 (defun tcl-set-proc-regexp () | |
485 "Set `tcl-proc-regexp' from variable `tcl-proc-list'." | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
486 (setq tcl-proc-regexp |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
487 (concat "^\\s-*" (regexp-opt tcl-proc-list t) "[ \t]+"))) |
6709 | 488 |
489 (defun tcl-set-font-lock-keywords () | |
490 "Set `tcl-font-lock-keywords'. | |
491 Uses variables `tcl-proc-regexp' and `tcl-keyword-list'." | |
492 (setq tcl-font-lock-keywords | |
493 (list | |
494 ;; Names of functions (and other "defining things"). | |
495 (list (concat tcl-proc-regexp "\\([^ \t\n]+\\)") | |
496 2 'font-lock-function-name-face) | |
497 | |
498 ;; Names of type-defining things. | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
499 (list (concat "\\(\\s-\\|^\\)" |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
500 (regexp-opt tcl-typeword-list t) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
501 "\\(\\s-\\|$\\)") |
6709 | 502 2 'font-lock-type-face) |
503 | |
61314
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
504 (list (concat "\\_<" (regexp-opt tcl-builtin-list t) "\\_>") |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
505 1 'font-lock-builtin-face) |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
506 |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
507 ;; When variable names are enclosed in {} braces, any |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
508 ;; character can be used. Otherwise just letters, digits, |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
509 ;; underscores. Variable names can be prefixed with any |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
510 ;; number of "namespace::" qualifiers. A leading "::" refers |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
511 ;; to the global namespace. |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
512 '("\\${\\([^}]+\\)}" 1 font-lock-variable-name-face) |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
513 '("\\$\\(\\(?:::\\)?\\(?:[[:alnum:]_]+::\\)*[[:alnum:]_]+\\)" |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
514 1 font-lock-variable-name-face) |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
515 '("\\(?:\\s-\\|^\\|\\[\\)set\\s-+{\\([^}]+\\)}" |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
516 1 font-lock-variable-name-face keep) |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
517 '("\\(?:\\s-\\|^\\|\\[\\)set\\s-+\\(\\(?:::\\)?\ |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
518 \\(?:[[:alnum:]_]+::\\)*[[:alnum:]_]+\\)" |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
519 1 font-lock-variable-name-face keep) |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
520 |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
521 '("\\(^\\|[^\\]\\)\\(\\\\\\\\\\)*\\(\\\\\\)$" 3 'tcl-escaped-newline) |
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
522 |
6709 | 523 ;; Keywords. Only recognized if surrounded by whitespace. |
524 ;; FIXME consider using "not word or symbol", not | |
525 ;; "whitespace". | |
61246
ee782d6579a8
(tcl-set-font-lock-keywords): Use new \_< ops.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58563
diff
changeset
|
526 (cons (concat "\\_<" (regexp-opt tcl-keyword-list t) "\\_>") |
61314
19126e0f7481
(tcl-escaped-newline): New face.
Glenn Morris <rgm@gnu.org>
parents:
61246
diff
changeset
|
527 1)))) |
6709 | 528 |
529 (if tcl-proc-regexp | |
530 () | |
531 (tcl-set-proc-regexp)) | |
532 | |
533 (if tcl-font-lock-keywords | |
534 () | |
535 (tcl-set-font-lock-keywords)) | |
536 | |
44316
443cf26a410a
(tcl-imenu-generic-expression): New value.
Richard M. Stallman <rms@gnu.org>
parents:
44227
diff
changeset
|
537 |
443cf26a410a
(tcl-imenu-generic-expression): New value.
Richard M. Stallman <rms@gnu.org>
parents:
44227
diff
changeset
|
538 (defvar tcl-imenu-generic-expression |
44320
40a69f39b79f
Change maintainer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44316
diff
changeset
|
539 `((nil ,(concat tcl-proc-regexp "\\([-A-Za-z0-9_:+*]+\\)") 2)) |
44316
443cf26a410a
(tcl-imenu-generic-expression): New value.
Richard M. Stallman <rms@gnu.org>
parents:
44227
diff
changeset
|
540 "Imenu generic expression for `tcl-mode'. See `imenu-generic-expression'.") |
443cf26a410a
(tcl-imenu-generic-expression): New value.
Richard M. Stallman <rms@gnu.org>
parents:
44227
diff
changeset
|
541 |
6709 | 542 |
543 | |
544 ;; | |
545 ;; The mode itself. | |
546 ;; | |
547 | |
8252
7d4674a34de3
Added ";;;###autoload" comments where appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7799
diff
changeset
|
548 ;;;###autoload |
109561
d7a517f1b312
Derive programming modes from prog-mode.
Juanma Barranquero <lekktu@gmail.com>
parents:
106815
diff
changeset
|
549 (define-derived-mode tcl-mode prog-mode "Tcl" |
6709 | 550 "Major mode for editing Tcl code. |
551 Expression and list commands understand all Tcl brackets. | |
552 Tab indents for Tcl code. | |
553 Paragraphs are separated by blank lines only. | |
554 Delete converts tabs to spaces as it moves back. | |
555 | |
556 Variables controlling indentation style: | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
557 `tcl-indent-level' |
6709 | 558 Indentation of Tcl statements within surrounding block. |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
559 `tcl-continued-indent-level' |
6709 | 560 Indentation of continuation line relative to first line of command. |
561 | |
562 Variables controlling user interaction with mode (see variable | |
563 documentation for details): | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
564 `tcl-tab-always-indent' |
6709 | 565 Controls action of TAB key. |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
566 `tcl-auto-newline' |
6709 | 567 Non-nil means automatically newline before and after braces, brackets, |
568 and semicolons inserted in Tcl code. | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
569 `tcl-use-smart-word-finder' |
12644 | 570 If not nil, use a smarter, Tcl-specific way to find the current |
571 word when looking up help on a Tcl command. | |
6709 | 572 |
49730
ce81e48eab6e
(tcl-omit-ws-regexp): Correctly handle cases like `proc foo {a {b c} d} {'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49598
diff
changeset
|
573 Turning on Tcl mode runs `tcl-mode-hook'. Read the documentation for |
6709 | 574 `tcl-mode-hook' to see what kinds of interesting hook functions |
575 already exist. | |
576 | |
577 Commands: | |
578 \\{tcl-mode-map}" | |
44316
443cf26a410a
(tcl-imenu-generic-expression): New value.
Richard M. Stallman <rms@gnu.org>
parents:
44227
diff
changeset
|
579 (unless (and (boundp 'filladapt-mode) filladapt-mode) |
48192
1acfacdf062a
(tcl-mode): Don't set paragraph-start,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44320
diff
changeset
|
580 (set (make-local-variable 'paragraph-ignore-fill-prefix) t)) |
7612 | 581 |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
582 (set (make-local-variable 'indent-line-function) 'tcl-indent-line) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
583 (set (make-local-variable 'comment-indent-function) 'tcl-comment-indent) |
6709 | 584 ;; Tcl doesn't require a final newline. |
585 ;; (make-local-variable 'require-final-newline) | |
586 ;; (setq require-final-newline t) | |
7612 | 587 |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
588 (set (make-local-variable 'comment-start) "# ") |
49730
ce81e48eab6e
(tcl-omit-ws-regexp): Correctly handle cases like `proc foo {a {b c} d} {'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49598
diff
changeset
|
589 (set (make-local-variable 'comment-start-skip) |
ce81e48eab6e
(tcl-omit-ws-regexp): Correctly handle cases like `proc foo {a {b c} d} {'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49598
diff
changeset
|
590 "\\(\\(^\\|[;{[]\\)\\s-*\\)#+ *") |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
591 (set (make-local-variable 'comment-end) "") |
11303
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
592 |
48192
1acfacdf062a
(tcl-mode): Don't set paragraph-start,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44320
diff
changeset
|
593 (set (make-local-variable 'outline-regexp) ".") |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
594 (set (make-local-variable 'outline-level) 'tcl-outline-level) |
7612 | 595 |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
596 (set (make-local-variable 'font-lock-defaults) |
110305
b10051866f51
New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109561
diff
changeset
|
597 '(tcl-font-lock-keywords nil nil nil beginning-of-defun)) |
b10051866f51
New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109561
diff
changeset
|
598 (set (make-local-variable 'syntax-propertize-function) |
b10051866f51
New syntax-propertize functionality.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
109561
diff
changeset
|
599 tcl-syntax-propertize-function) |
12517
2f90abd1c659
(tcl-mode): Customize for new dabbrev.
Tom Tromey <tromey@redhat.com>
parents:
12515
diff
changeset
|
600 |
44316
443cf26a410a
(tcl-imenu-generic-expression): New value.
Richard M. Stallman <rms@gnu.org>
parents:
44227
diff
changeset
|
601 (set (make-local-variable 'imenu-generic-expression) |
51492
168bf1dc1b53
(tcl-mode): Set imenu-generic-expression to the value of
Juanma Barranquero <lekktu@gmail.com>
parents:
51056
diff
changeset
|
602 tcl-imenu-generic-expression) |
49598
0d8b17d428b5
Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48192
diff
changeset
|
603 |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
604 ;; Settings for new dabbrev code. |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
605 (set (make-local-variable 'dabbrev-case-fold-search) nil) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
606 (set (make-local-variable 'dabbrev-case-replace) nil) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
607 (set (make-local-variable 'dabbrev-abbrev-skip-leading-regexp) "[$!]") |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
608 (set (make-local-variable 'dabbrev-abbrev-char-regexp) "\\sw\\|\\s_") |
7612 | 609 |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
610 ;; This can only be set to t in Emacs 19 and XEmacs. |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
611 ;; Emacs 18 and Epoch lose. |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
612 (set (make-local-variable 'parse-sexp-ignore-comments) t) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
613 ;; XEmacs has defun-prompt-regexp, but I don't believe |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
614 ;; that it works for end-of-defun -- only for |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
615 ;; beginning-of-defun. |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
616 (set (make-local-variable 'defun-prompt-regexp) tcl-omit-ws-regexp) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
617 ;; The following doesn't work in Lucid Emacs 19.6, but maybe |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
618 ;; it will appear in later versions. |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
619 (set (make-local-variable 'add-log-current-defun-function) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
620 'tcl-add-log-defun) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
621 |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
622 (easy-menu-add tcl-mode-menu) |
11787
635f5fb5d82a
Changed "Lucid Emacs" to "XEmacs".
Tom Tromey <tromey@redhat.com>
parents:
11303
diff
changeset
|
623 ;; Append Tcl menu to popup menu for XEmacs. |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
624 (if (boundp 'mode-popup-menu) |
12520
ad24dd8cec5c
Changes to make menus work in XEmacs.
Tom Tromey <tromey@redhat.com>
parents:
12517
diff
changeset
|
625 (setq mode-popup-menu |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
626 (cons (concat mode-name " Mode Commands") tcl-mode-menu)))) |
6709 | 627 |
628 | |
629 | |
630 ;; This is used for braces, brackets, and semi (except for closing | |
631 ;; braces, which are handled specially). | |
632 (defun tcl-electric-char (arg) | |
633 "Insert character and correct line's indentation." | |
634 (interactive "p") | |
635 ;; Indent line first; this looks better if parens blink. | |
636 (tcl-indent-line) | |
637 (self-insert-command arg) | |
101002
3b3c7e10cd97
Replace last-command-char with last-command-event.
Glenn Morris <rgm@gnu.org>
parents:
100908
diff
changeset
|
638 (if (and tcl-auto-newline (= last-command-event ?\;)) |
6709 | 639 (progn |
640 (newline) | |
641 (tcl-indent-line)))) | |
642 | |
643 ;; This is used for closing braces. If tcl-auto-newline is set, can | |
644 ;; insert a newline both before and after the brace, depending on | |
645 ;; context. FIXME should this be configurable? Does anyone use this? | |
646 (defun tcl-electric-brace (arg) | |
647 "Insert character and correct line's indentation." | |
648 (interactive "p") | |
649 ;; If auto-newlining and there is stuff on the same line, insert a | |
650 ;; newline first. | |
651 (if tcl-auto-newline | |
652 (progn | |
653 (if (save-excursion | |
654 (skip-chars-backward " \t") | |
655 (bolp)) | |
656 () | |
657 (tcl-indent-line) | |
658 (newline)) | |
659 ;; In auto-newline case, must insert a newline after each | |
660 ;; brace. So an explicit loop is needed. | |
661 (while (> arg 0) | |
101002
3b3c7e10cd97
Replace last-command-char with last-command-event.
Glenn Morris <rgm@gnu.org>
parents:
100908
diff
changeset
|
662 (insert last-command-event) |
6709 | 663 (tcl-indent-line) |
664 (newline) | |
665 (setq arg (1- arg)))) | |
666 (self-insert-command arg)) | |
667 (tcl-indent-line)) | |
668 | |
669 | |
670 | |
671 (defun tcl-indent-command (&optional arg) | |
672 "Indent current line as Tcl code, or in some cases insert a tab character. | |
25163 | 673 If `tcl-tab-always-indent' is t (the default), always indent current line. |
674 If `tcl-tab-always-indent' is nil and point is not in the indentation | |
6709 | 675 area at the beginning of the line, a TAB is inserted. |
25163 | 676 Other values of `tcl-tab-always-indent' cause the first possible action |
6709 | 677 from the following list to take place: |
678 | |
679 1. Move from beginning of line to correct indentation. | |
680 2. Delete an empty comment. | |
681 3. Move forward to start of comment, indenting if necessary. | |
682 4. Move forward to end of line, indenting if necessary. | |
683 5. Create an empty comment. | |
684 6. Move backward to start of comment, indenting if necessary." | |
685 (interactive "p") | |
68124
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
686 (if (memq tcl-tab-always-indent '(nil t)) |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
687 (let ((tab-always-indent tcl-tab-always-indent)) |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
688 (call-interactively 'indent-for-tab-command)) |
6709 | 689 ;; "Perl-mode" style TAB command. |
690 (let* ((ipoint (point)) | |
691 (eolpoint (progn | |
692 (end-of-line) | |
693 (point))) | |
694 (comment-p (tcl-in-comment))) | |
695 (cond | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
696 ((= ipoint (line-beginning-position)) |
6709 | 697 (beginning-of-line) |
698 (tcl-indent-line) | |
699 ;; If indenting didn't leave us in column 0, go to the | |
700 ;; indentation. Otherwise leave point at end of line. This | |
701 ;; is a hack. | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
702 (if (= (point) (line-beginning-position)) |
6709 | 703 (end-of-line) |
704 (back-to-indentation))) | |
705 ((and comment-p (looking-at "[ \t]*$")) | |
706 ;; Empty comment, so delete it. We also delete any ";" | |
707 ;; characters at the end of the line. I think this is | |
708 ;; friendlier, but I don't know how other people will feel. | |
709 (backward-char) | |
710 (skip-chars-backward " \t;") | |
711 (delete-region (point) eolpoint)) | |
712 ((and comment-p (< ipoint (point))) | |
713 ;; Before comment, so skip to it. | |
714 (tcl-indent-line) | |
715 (indent-for-comment)) | |
716 ((/= ipoint eolpoint) | |
717 ;; Go to end of line (since we're not there yet). | |
718 (goto-char eolpoint) | |
719 (tcl-indent-line)) | |
720 ((not comment-p) | |
721 (tcl-indent-line) | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
722 (comment-indent)) |
6709 | 723 (t |
724 ;; Go to start of comment. We don't leave point where it is | |
725 ;; because we want to skip comment-start-skip. | |
726 (tcl-indent-line) | |
68124
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
727 (indent-for-comment)))))) |
6709 | 728 |
729 (defun tcl-indent-line () | |
730 "Indent current line as Tcl code. | |
731 Return the amount the indentation changed by." | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
732 (let ((indent (tcl-calculate-indent nil)) |
6709 | 733 beg shift-amt |
734 (case-fold-search nil) | |
735 (pos (- (point-max) (point)))) | |
68124
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
736 (if (null indent) |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
737 'noindent |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
738 (beginning-of-line) |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
739 (setq beg (point)) |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
740 (skip-chars-forward " \t") |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
741 (if (listp indent) (setq indent (car indent))) |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
742 (cond ((= (following-char) ?}) |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
743 (setq indent (- indent tcl-indent-level))) |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
744 ((= (following-char) ?\]) |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
745 (setq indent (- indent 1)))) |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
746 (skip-chars-forward " \t") |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
747 (setq shift-amt (- indent (current-column))) |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
748 (if (zerop shift-amt) |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
749 (if (> (- (point-max) pos) (point)) |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
750 (goto-char (- (point-max) pos))) |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
751 (delete-region beg (point)) |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
752 (indent-to indent) |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
753 ;; If initial point was within line's indentation, |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
754 ;; position after the indentation. Else stay at same point in text. |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
755 (if (> (- (point-max) pos) (point)) |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
756 (goto-char (- (point-max) pos)))) |
32fc565ba875
(tcl-indent-command): Use indent-for-tab-command.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
66963
diff
changeset
|
757 shift-amt))) |
6709 | 758 |
759 (defun tcl-figure-type () | |
760 "Determine type of sexp at point. | |
25163 | 761 This is either `tcl-expr', `tcl-commands', or nil. Puts point at start |
6709 | 762 of sexp that indicates types. |
763 | |
764 See documentation for variable `tcl-type-alist' for more information." | |
765 (let ((count 0) | |
766 result | |
767 word-stack) | |
768 (while (and (< count 5) | |
769 (not result)) | |
770 (condition-case nil | |
771 (progn | |
772 ;; FIXME should use "tcl-backward-sexp", which would skip | |
773 ;; over entire variables, etc. | |
774 (backward-sexp) | |
775 (if (looking-at "[a-zA-Z_]+") | |
776 (let ((list tcl-type-alist) | |
777 entry) | |
12645
3ce3ca90e4a3
(tcl-word-no-props): New function.
Tom Tromey <tromey@redhat.com>
parents:
12644
diff
changeset
|
778 (setq word-stack (cons (tcl-word-no-props) word-stack)) |
6709 | 779 (while (and list (not result)) |
780 (setq entry (car list)) | |
781 (setq list (cdr list)) | |
782 (let ((index 0)) | |
783 (while (and entry (<= index count)) | |
784 ;; Abort loop if string does not match word on | |
785 ;; stack. | |
786 (and (stringp (car entry)) | |
787 (not (string= (car entry) | |
788 (nth index word-stack))) | |
789 (setq entry nil)) | |
790 (setq entry (cdr entry)) | |
791 (setq index (1+ index))) | |
792 (and (> index count) | |
793 (not (stringp (car entry))) | |
794 (setq result (car entry))) | |
795 ))) | |
796 (setq word-stack (cons nil word-stack)))) | |
797 (error nil)) | |
798 (setq count (1+ count))) | |
799 (and tcl-explain-indentation | |
800 (message "Indentation type %s" result)) | |
801 result)) | |
802 | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
803 (defun tcl-calculate-indent (&optional parse-start) |
6709 | 804 "Return appropriate indentation for current line as Tcl code. |
805 In usual case returns an integer: the column to indent to. | |
806 Returns nil if line starts inside a string, t if in a comment." | |
807 (save-excursion | |
808 (beginning-of-line) | |
809 (let* ((indent-point (point)) | |
810 (case-fold-search nil) | |
49598
0d8b17d428b5
Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48192
diff
changeset
|
811 (continued-line |
6709 | 812 (save-excursion |
813 (if (bobp) | |
814 nil | |
815 (backward-char) | |
816 (= ?\\ (preceding-char))))) | |
817 (continued-indent-value (if continued-line | |
818 tcl-continued-indent-level | |
819 0)) | |
820 state | |
821 containing-sexp | |
822 found-next-line) | |
823 (if parse-start | |
824 (goto-char parse-start) | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
825 (beginning-of-defun)) |
6709 | 826 (while (< (point) indent-point) |
827 (setq parse-start (point)) | |
828 (setq state (parse-partial-sexp (point) indent-point 0)) | |
829 (setq containing-sexp (car (cdr state)))) | |
830 (cond ((or (nth 3 state) (nth 4 state)) | |
831 ;; Inside comment or string. Return nil or t if should | |
832 ;; not change this line | |
833 (nth 4 state)) | |
834 ((null containing-sexp) | |
835 ;; Line is at top level. | |
836 continued-indent-value) | |
837 (t | |
838 ;; Set expr-p if we are looking at the expression part of | |
839 ;; an "if", "expr", etc statement. Set commands-p if we | |
840 ;; are looking at the body part of an if, while, etc | |
841 ;; statement. FIXME Should check for "for" loops here. | |
842 (goto-char containing-sexp) | |
843 (let* ((sexpr-type (tcl-figure-type)) | |
844 (expr-p (eq sexpr-type 'tcl-expr)) | |
845 (commands-p (eq sexpr-type 'tcl-commands)) | |
846 (expr-start (point))) | |
847 ;; Find the first statement in the block and indent | |
848 ;; like it. The first statement in the block might be | |
849 ;; on the same line, so what we do is skip all | |
850 ;; "virtually blank" lines, looking for a non-blank | |
851 ;; one. A line is virtually blank if it only contains | |
852 ;; a comment and whitespace. FIXME continued comments | |
853 ;; aren't supported. They are a wart on Tcl anyway. | |
854 ;; We do it this funky way because we want to know if | |
855 ;; we've found a statement on some line _after_ the | |
856 ;; line holding the sexp opener. | |
857 (goto-char containing-sexp) | |
858 (forward-char) | |
859 (if (and (< (point) indent-point) | |
860 (looking-at "[ \t]*\\(#.*\\)?$")) | |
861 (progn | |
862 (forward-line) | |
863 (while (and (< (point) indent-point) | |
864 (looking-at "[ \t]*\\(#.*\\)?$")) | |
865 (setq found-next-line t) | |
866 (forward-line)))) | |
867 (if (or continued-line | |
868 (/= (char-after containing-sexp) ?{) | |
869 expr-p) | |
870 (progn | |
871 ;; Line is continuation line, or the sexp opener | |
872 ;; is not a curly brace, or we are are looking at | |
873 ;; an `expr' expression (which must be split | |
874 ;; specially). So indentation is column of first | |
875 ;; good spot after sexp opener (with some added | |
876 ;; in the continued-line case). If there is no | |
877 ;; nonempty line before the indentation point, we | |
878 ;; use the column of the character after the sexp | |
879 ;; opener. | |
880 (if (>= (point) indent-point) | |
881 (progn | |
882 (goto-char containing-sexp) | |
883 (forward-char)) | |
884 (skip-chars-forward " \t")) | |
885 (+ (current-column) continued-indent-value)) | |
886 ;; After a curly brace, and not a continuation line. | |
887 ;; So take indentation from first good line after | |
888 ;; start of block, unless that line is on the same | |
889 ;; line as the opening brace. In this case use the | |
890 ;; indentation of the opening brace's line, plus | |
891 ;; another indent step. If we are in the body part | |
892 ;; of an "if" or "while" then the indentation is | |
893 ;; taken from the line holding the start of the | |
894 ;; statement. | |
895 (if (and (< (point) indent-point) | |
896 found-next-line) | |
897 (current-indentation) | |
898 (if commands-p | |
899 (goto-char expr-start) | |
900 (goto-char containing-sexp)) | |
901 (+ (current-indentation) tcl-indent-level))))))))) | |
902 | |
903 | |
904 | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
905 (defun tcl-indent-exp () |
6709 | 906 "Indent each line of the Tcl grouping following point." |
907 (interactive) | |
908 (let ((indent-stack (list nil)) | |
909 (contain-stack (list (point))) | |
910 (case-fold-search nil) | |
911 outer-loop-done inner-loop-done state ostate | |
51056
5dbeffb17d8e
(tcl-indent-exp): Remove dead code.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
50856
diff
changeset
|
912 this-indent continued-line |
6709 | 913 (next-depth 0) |
914 last-depth) | |
915 (save-excursion | |
916 (forward-sexp 1)) | |
917 (save-excursion | |
918 (setq outer-loop-done nil) | |
919 (while (and (not (eobp)) (not outer-loop-done)) | |
920 (setq last-depth next-depth) | |
921 ;; Compute how depth changes over this line | |
922 ;; plus enough other lines to get to one that | |
923 ;; does not end inside a comment or string. | |
924 ;; Meanwhile, do appropriate indentation on comment lines. | |
925 (setq inner-loop-done nil) | |
926 (while (and (not inner-loop-done) | |
927 (not (and (eobp) (setq outer-loop-done t)))) | |
928 (setq ostate state) | |
929 (setq state (parse-partial-sexp (point) (progn (end-of-line) (point)) | |
930 nil nil state)) | |
931 (setq next-depth (car state)) | |
932 (if (or (nth 4 ostate)) | |
933 (tcl-indent-line)) | |
934 (if (or (nth 3 state)) | |
935 (forward-line 1) | |
936 (setq inner-loop-done t))) | |
937 (if (<= next-depth 0) | |
938 (setq outer-loop-done t)) | |
939 (if outer-loop-done | |
940 nil | |
941 ;; If this line had ..))) (((.. in it, pop out of the levels | |
942 ;; that ended anywhere in this line, even if the final depth | |
943 ;; doesn't indicate that they ended. | |
944 (while (> last-depth (nth 6 state)) | |
945 (setq indent-stack (cdr indent-stack) | |
946 contain-stack (cdr contain-stack) | |
947 last-depth (1- last-depth))) | |
948 ;; Add levels for any parens that were started in this line. | |
949 (while (< last-depth next-depth) | |
950 (setq indent-stack (cons nil indent-stack) | |
951 contain-stack (cons nil contain-stack) | |
952 last-depth (1+ last-depth))) | |
953 (if (null (car contain-stack)) | |
49598
0d8b17d428b5
Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48192
diff
changeset
|
954 (setcar contain-stack |
6709 | 955 (or (car (cdr state)) |
956 (save-excursion | |
957 (forward-sexp -1) | |
958 (point))))) | |
959 (forward-line 1) | |
49598
0d8b17d428b5
Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48192
diff
changeset
|
960 (setq continued-line |
6709 | 961 (save-excursion |
962 (backward-char) | |
963 (= (preceding-char) ?\\))) | |
964 (skip-chars-forward " \t") | |
965 (if (eolp) | |
966 nil | |
967 (if (and (car indent-stack) | |
968 (>= (car indent-stack) 0)) | |
969 ;; Line is on an existing nesting level. | |
970 (setq this-indent (car indent-stack)) | |
971 ;; Just started a new nesting level. | |
972 ;; Compute the standard indent for this level. | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
973 (let ((val (tcl-calculate-indent |
6709 | 974 (if (car indent-stack) |
975 (- (car indent-stack)))))) | |
976 (setcar indent-stack | |
977 (setq this-indent val)) | |
978 (setq continued-line nil))) | |
979 (cond ((not (numberp this-indent))) | |
980 ((= (following-char) ?}) | |
981 (setq this-indent (- this-indent tcl-indent-level))) | |
982 ((= (following-char) ?\]) | |
983 (setq this-indent (- this-indent 1)))) | |
984 ;; Put chosen indentation into effect. | |
985 (or (null this-indent) | |
49598
0d8b17d428b5
Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48192
diff
changeset
|
986 (= (current-column) |
0d8b17d428b5
Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48192
diff
changeset
|
987 (if continued-line |
6709 | 988 (+ this-indent tcl-indent-level) |
989 this-indent)) | |
990 (progn | |
991 (delete-region (point) (progn (beginning-of-line) (point))) | |
49598
0d8b17d428b5
Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48192
diff
changeset
|
992 (indent-to |
0d8b17d428b5
Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48192
diff
changeset
|
993 (if continued-line |
6709 | 994 (+ this-indent tcl-indent-level) |
995 this-indent))))))))) | |
996 ) | |
997 | |
998 | |
999 | |
1000 ;; | |
1001 ;; Interfaces to other packages. | |
1002 ;; | |
1003 | |
1004 ;; FIXME Definition of function is very ad-hoc. Should use | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1005 ;; beginning-of-defun. Also has incestuous knowledge about the |
6709 | 1006 ;; format of tcl-proc-regexp. |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1007 (defun tcl-add-log-defun () |
6709 | 1008 "Return name of Tcl function point is in, or nil." |
1009 (save-excursion | |
13698
a5b05f960c30
(add-log-tcl-defun): Don't use tcl-beginning-of-defun; just go to end
Tom Tromey <tromey@redhat.com>
parents:
13697
diff
changeset
|
1010 (end-of-line) |
a5b05f960c30
(add-log-tcl-defun): Don't use tcl-beginning-of-defun; just go to end
Tom Tromey <tromey@redhat.com>
parents:
13697
diff
changeset
|
1011 (if (re-search-backward (concat tcl-proc-regexp "\\([^ \t\n{]+\\)") nil t) |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1012 (match-string 2)))) |
6709 | 1013 |
11303
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
1014 (defun tcl-outline-level () |
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
1015 (save-excursion |
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
1016 (skip-chars-forward " \t") |
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
1017 (current-column))) |
7823947372f9
(tcl-outline-level): New function
Tom Tromey <tromey@redhat.com>
parents:
9428
diff
changeset
|
1018 |
6709 | 1019 |
1020 | |
1021 ;; | |
1022 ;; Helper functions for inferior Tcl mode. | |
1023 ;; | |
1024 | |
1025 ;; This exists to let us delete the prompt when commands are sent | |
1026 ;; directly to the inferior Tcl. See gud.el for an explanation of how | |
1027 ;; it all works (I took it from there). This stuff doesn't really | |
1028 ;; work as well as I'd like it to. But I don't believe there is | |
1029 ;; anything useful that can be done. | |
1030 (defvar inferior-tcl-delete-prompt-marker nil) | |
1031 | |
1032 (defun tcl-filter (proc string) | |
99776
46cd7381c2ff
(tcl-filter): Don't forcibly move point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
94673
diff
changeset
|
1033 (let ((inhibit-quit t)) ;FIXME: Isn't that redundant? |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1034 (with-current-buffer (process-buffer proc) |
6709 | 1035 ;; Delete prompt if requested. |
99776
46cd7381c2ff
(tcl-filter): Don't forcibly move point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
94673
diff
changeset
|
1036 (when (marker-buffer inferior-tcl-delete-prompt-marker) |
46cd7381c2ff
(tcl-filter): Don't forcibly move point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
94673
diff
changeset
|
1037 (delete-region (process-mark proc) inferior-tcl-delete-prompt-marker) |
46cd7381c2ff
(tcl-filter): Don't forcibly move point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
94673
diff
changeset
|
1038 (set-marker inferior-tcl-delete-prompt-marker nil)))) |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1039 (comint-output-filter proc string)) |
6709 | 1040 |
1041 (defun tcl-send-string (proc string) | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1042 (with-current-buffer (process-buffer proc) |
6709 | 1043 (goto-char (process-mark proc)) |
70093
da16308f67d1
(tcl-send-string, tcl-send-region): Use forward-line so as to get to BOL
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68124
diff
changeset
|
1044 (forward-line 0) ;Not (beginning-of-line) because of fields. |
6709 | 1045 (if (looking-at comint-prompt-regexp) |
1046 (set-marker inferior-tcl-delete-prompt-marker (point)))) | |
1047 (comint-send-string proc string)) | |
1048 | |
1049 (defun tcl-send-region (proc start end) | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1050 (with-current-buffer (process-buffer proc) |
6709 | 1051 (goto-char (process-mark proc)) |
70093
da16308f67d1
(tcl-send-string, tcl-send-region): Use forward-line so as to get to BOL
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68124
diff
changeset
|
1052 (forward-line 0) ;Not (beginning-of-line) because of fields. |
6709 | 1053 (if (looking-at comint-prompt-regexp) |
1054 (set-marker inferior-tcl-delete-prompt-marker (point)))) | |
1055 (comint-send-region proc start end)) | |
1056 | |
1057 (defun switch-to-tcl (eob-p) | |
1058 "Switch to inferior Tcl process buffer. | |
1059 With argument, positions cursor at end of buffer." | |
1060 (interactive "P") | |
1061 (if (get-buffer inferior-tcl-buffer) | |
1062 (pop-to-buffer inferior-tcl-buffer) | |
1063 (error "No current inferior Tcl buffer")) | |
1064 (cond (eob-p | |
1065 (push-mark) | |
1066 (goto-char (point-max))))) | |
1067 | |
1068 (defun inferior-tcl-proc () | |
1069 "Return current inferior Tcl process. | |
1070 See variable `inferior-tcl-buffer'." | |
1071 (let ((proc (get-buffer-process (if (eq major-mode 'inferior-tcl-mode) | |
1072 (current-buffer) | |
1073 inferior-tcl-buffer)))) | |
1074 (or proc | |
1075 (error "No Tcl process; see variable `inferior-tcl-buffer'")))) | |
1076 | |
1077 (defun tcl-eval-region (start end &optional and-go) | |
1078 "Send the current region to the inferior Tcl process. | |
1079 Prefix argument means switch to the Tcl buffer afterwards." | |
1080 (interactive "r\nP") | |
1081 (let ((proc (inferior-tcl-proc))) | |
70093
da16308f67d1
(tcl-send-string, tcl-send-region): Use forward-line so as to get to BOL
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68124
diff
changeset
|
1082 (tcl-send-region |
da16308f67d1
(tcl-send-string, tcl-send-region): Use forward-line so as to get to BOL
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68124
diff
changeset
|
1083 proc |
da16308f67d1
(tcl-send-string, tcl-send-region): Use forward-line so as to get to BOL
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68124
diff
changeset
|
1084 ;; Strip leading and trailing whitespace. |
da16308f67d1
(tcl-send-string, tcl-send-region): Use forward-line so as to get to BOL
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68124
diff
changeset
|
1085 (save-excursion (goto-char start) (skip-chars-forward " \t\n") (point)) |
da16308f67d1
(tcl-send-string, tcl-send-region): Use forward-line so as to get to BOL
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68124
diff
changeset
|
1086 (save-excursion (goto-char end) (skip-chars-backward " \t\n") (point))) |
6709 | 1087 (tcl-send-string proc "\n") |
1088 (if and-go (switch-to-tcl t)))) | |
1089 | |
1090 (defun tcl-eval-defun (&optional and-go) | |
1091 "Send the current defun to the inferior Tcl process. | |
1092 Prefix argument means switch to the Tcl buffer afterwards." | |
1093 (interactive "P") | |
1094 (save-excursion | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1095 (end-of-defun) |
6709 | 1096 (let ((end (point))) |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1097 (beginning-of-defun) |
6709 | 1098 (tcl-eval-region (point) end))) |
1099 (if and-go (switch-to-tcl t))) | |
1100 | |
1101 | |
1102 | |
1103 ;; | |
1104 ;; Inferior Tcl mode itself. | |
1105 ;; | |
1106 | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1107 (define-derived-mode inferior-tcl-mode comint-mode "Inferior Tcl" |
6709 | 1108 "Major mode for interacting with Tcl interpreter. |
1109 | |
44316
443cf26a410a
(tcl-imenu-generic-expression): New value.
Richard M. Stallman <rms@gnu.org>
parents:
44227
diff
changeset
|
1110 You can start a Tcl process with \\[inferior-tcl]. |
6709 | 1111 |
25163 | 1112 Entry to this mode runs the normal hooks `comint-mode-hook' and |
1113 `inferior-tcl-mode-hook', in that order. | |
6709 | 1114 |
1115 You can send text to the inferior Tcl process from other buffers | |
1116 containing Tcl source. | |
1117 | |
1118 Variables controlling Inferior Tcl mode: | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1119 `tcl-application' |
6709 | 1120 Name of program to run. |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1121 `tcl-command-switches' |
6709 | 1122 Command line arguments to `tcl-application'. |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1123 `tcl-prompt-regexp' |
6709 | 1124 Matches prompt. |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1125 `inferior-tcl-source-command' |
6709 | 1126 Command to use to read Tcl file in running application. |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1127 `inferior-tcl-buffer' |
6709 | 1128 The current inferior Tcl process buffer. See variable |
1129 documentation for details on multiple-process support. | |
1130 | |
1131 The following commands are available: | |
1132 \\{inferior-tcl-mode-map}" | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1133 (set (make-local-variable 'comint-prompt-regexp) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1134 (or tcl-prompt-regexp |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1135 (concat "^" (regexp-quote tcl-application) ">"))) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1136 (setq mode-line-process '(": %s")) |
6709 | 1137 (setq local-abbrev-table tcl-mode-abbrev-table) |
1138 (set-syntax-table tcl-mode-syntax-table) | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1139 (set (make-local-variable 'defun-prompt-regexp) tcl-omit-ws-regexp) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1140 (set (make-local-variable 'inferior-tcl-delete-prompt-marker) (make-marker)) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1141 (set-process-filter (get-buffer-process (current-buffer)) 'tcl-filter)) |
6709 | 1142 |
8252
7d4674a34de3
Added ";;;###autoload" comments where appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7799
diff
changeset
|
1143 ;;;###autoload |
6709 | 1144 (defun inferior-tcl (cmd) |
1145 "Run inferior Tcl process. | |
1146 Prefix arg means enter program name interactively. | |
1147 See documentation for function `inferior-tcl-mode' for more information." | |
1148 (interactive | |
1149 (list (if current-prefix-arg | |
1150 (read-string "Run Tcl: " tcl-application) | |
1151 tcl-application))) | |
57188
03a731220a33
* progmodes/tcl.el (inferior-tcl): Use pop-to-buffer.
Jesper Harder <harder@ifa.au.dk>
parents:
54770
diff
changeset
|
1152 (unless (comint-check-proc "*inferior-tcl*") |
03a731220a33
* progmodes/tcl.el (inferior-tcl): Use pop-to-buffer.
Jesper Harder <harder@ifa.au.dk>
parents:
54770
diff
changeset
|
1153 (set-buffer (apply (function make-comint) "inferior-tcl" cmd nil |
03a731220a33
* progmodes/tcl.el (inferior-tcl): Use pop-to-buffer.
Jesper Harder <harder@ifa.au.dk>
parents:
54770
diff
changeset
|
1154 tcl-command-switches)) |
70093
da16308f67d1
(tcl-send-string, tcl-send-region): Use forward-line so as to get to BOL
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68124
diff
changeset
|
1155 (inferior-tcl-mode) |
da16308f67d1
(tcl-send-string, tcl-send-region): Use forward-line so as to get to BOL
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68124
diff
changeset
|
1156 ;; Make tclsh display a prompt on ms-windows (or under Unix, when a tty |
da16308f67d1
(tcl-send-string, tcl-send-region): Use forward-line so as to get to BOL
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68124
diff
changeset
|
1157 ;; wasn't used). Doesn't affect wish, unfortunately. |
da16308f67d1
(tcl-send-string, tcl-send-region): Use forward-line so as to get to BOL
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68124
diff
changeset
|
1158 (unless (process-tty-name (inferior-tcl-proc)) |
da16308f67d1
(tcl-send-string, tcl-send-region): Use forward-line so as to get to BOL
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68124
diff
changeset
|
1159 (tcl-send-string (inferior-tcl-proc) |
da16308f67d1
(tcl-send-string, tcl-send-region): Use forward-line so as to get to BOL
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68124
diff
changeset
|
1160 "set ::tcl_interactive 1; concat\n"))) |
57188
03a731220a33
* progmodes/tcl.el (inferior-tcl): Use pop-to-buffer.
Jesper Harder <harder@ifa.au.dk>
parents:
54770
diff
changeset
|
1161 (set (make-local-variable 'tcl-application) cmd) |
6709 | 1162 (setq inferior-tcl-buffer "*inferior-tcl*") |
57188
03a731220a33
* progmodes/tcl.el (inferior-tcl): Use pop-to-buffer.
Jesper Harder <harder@ifa.au.dk>
parents:
54770
diff
changeset
|
1163 (pop-to-buffer "*inferior-tcl*")) |
6709 | 1164 |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1165 (defalias 'run-tcl 'inferior-tcl) |
6709 | 1166 |
1167 | |
1168 | |
1169 ;; | |
1170 ;; Auto-fill support. | |
1171 ;; | |
1172 | |
1173 (defun tcl-real-command-p () | |
1174 "Return nil if point is not at the beginning of a command. | |
1175 A command is the first word on an otherwise empty line, or the | |
1176 first word following a semicolon, opening brace, or opening bracket." | |
1177 (save-excursion | |
1178 (skip-chars-backward " \t") | |
1179 (cond | |
1180 ((bobp) t) | |
1181 ((bolp) | |
1182 (backward-char) | |
1183 ;; Note -- continued comments are not supported here. I | |
1184 ;; consider those to be a wart on the language. | |
1185 (not (eq ?\\ (preceding-char)))) | |
1186 (t | |
1187 (memq (preceding-char) '(?\; ?{ ?\[)))))) | |
1188 | |
1189 ;; FIXME doesn't actually return t. See last case. | |
1190 (defun tcl-real-comment-p () | |
1191 "Return t if point is just after the `#' beginning a real comment. | |
1192 Does not check to see if previous char is actually `#'. | |
1193 A real comment is either at the beginning of the buffer, | |
44227
a1c4f9151348
(tcl-imenu-create-index-function): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
43437
diff
changeset
|
1194 preceded only by whitespace on the line, or has a preceding |
6709 | 1195 semicolon, opening brace, or opening bracket on the same line." |
1196 (save-excursion | |
1197 (backward-char) | |
1198 (tcl-real-command-p))) | |
1199 | |
1200 (defun tcl-hairy-scan-for-comment (state end always-stop) | |
1201 "Determine if point is in a comment. | |
1202 Returns a list of the form `(FLAG . STATE)'. STATE can be used | |
1203 as input to future invocations. FLAG is nil if not in comment, | |
1204 t otherwise. If in comment, leaves point at beginning of comment. | |
25163 | 1205 |
1206 This function does not work in Emacs 18. | |
1207 See also `tcl-simple-scan-for-comment', a | |
6709 | 1208 simpler version that is often right, and works in Emacs 18." |
1209 (let ((bol (save-excursion | |
1210 (goto-char end) | |
1211 (beginning-of-line) | |
1212 (point))) | |
1213 real-comment | |
1214 last-cstart) | |
1215 (while (and (not last-cstart) (< (point) end)) | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1216 (setq real-comment nil) ;In case we've looped around and it is set. |
6709 | 1217 (setq state (parse-partial-sexp (point) end nil nil state t)) |
1218 (if (nth 4 state) | |
1219 (progn | |
1220 ;; If ALWAYS-STOP is set, stop even if we don't have a | |
1221 ;; real comment, or if the comment isn't on the same line | |
1222 ;; as the end. | |
1223 (if always-stop (setq last-cstart (point))) | |
1224 ;; If we have a real comment, then set the comment | |
1225 ;; starting point if we are on the same line as the ending | |
1226 ;; location. | |
1227 (setq real-comment (tcl-real-comment-p)) | |
1228 (if real-comment | |
1229 (progn | |
1230 (and (> (point) bol) (setq last-cstart (point))) | |
1231 ;; NOTE Emacs 19 has a misfeature whereby calling | |
1232 ;; parse-partial-sexp with COMMENTSTOP set and with | |
1233 ;; an initial list that says point is in a comment | |
1234 ;; will cause an immediate return. So we must skip | |
1235 ;; over the comment ourselves. | |
1236 (beginning-of-line 2))) | |
1237 ;; Frob the state to make it look like we aren't in a | |
1238 ;; comment. | |
1239 (setcar (nthcdr 4 state) nil)))) | |
1240 (and last-cstart | |
1241 (goto-char last-cstart)) | |
1242 (cons real-comment state))) | |
1243 | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1244 (defun tcl-in-comment () |
25163 | 1245 "Return t if point is in a comment, and leave point at beginning of comment." |
6709 | 1246 (let ((save (point))) |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1247 (beginning-of-defun) |
6709 | 1248 (car (tcl-hairy-scan-for-comment nil save nil)))) |
7628 | 1249 |
6709 | 1250 |
1251 | |
1252 ;; | |
1253 ;; Help-related code. | |
1254 ;; | |
1255 | |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1256 (defvar tcl-help-saved-dirs nil |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1257 "Saved help directories. |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1258 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
|
1259 to update the alist.") |
6709 | 1260 |
1261 (defvar tcl-help-alist nil | |
1262 "Alist with command names as keys and filenames as values.") | |
1263 | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1264 (defun tcl-files-alist (dir &optional alist) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1265 "Recursively add all pairs (FILE . PATH) under DIR to ALIST." |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1266 (dolist (file (directory-files dir t) alist) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1267 (cond |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1268 ((not (file-directory-p file)) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1269 (push (cons (file-name-nondirectory file) file) alist)) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1270 ((member (file-name-nondirectory file) '("." ".."))) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1271 (t (setq alist (tcl-files-alist file alist)))))) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1272 |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1273 (defun tcl-help-snarf-commands (dirlist) |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1274 "Return alist of commands and filenames." |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1275 (let ((alist nil)) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1276 (dolist (dir dirlist alist) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1277 (when (file-directory-p dir) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1278 (setq alist (tcl-files-alist dir alist)))))) |
6709 | 1279 |
1280 (defun tcl-reread-help-files () | |
1281 "Set up to re-read files, and then do it." | |
1282 (interactive) | |
1283 (message "Building Tcl help file index...") | |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1284 (setq tcl-help-saved-dirs tcl-help-directory-list) |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1285 (setq tcl-help-alist (tcl-help-snarf-commands tcl-help-directory-list)) |
6709 | 1286 (message "Building Tcl help file index...done")) |
1287 | |
12645
3ce3ca90e4a3
(tcl-word-no-props): New function.
Tom Tromey <tromey@redhat.com>
parents:
12644
diff
changeset
|
1288 (defun tcl-word-no-props () |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1289 "Like `current-word', but strips properties." |
12645
3ce3ca90e4a3
(tcl-word-no-props): New function.
Tom Tromey <tromey@redhat.com>
parents:
12644
diff
changeset
|
1290 (let ((word (current-word))) |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1291 (set-text-properties 0 (length word) nil word) |
12645
3ce3ca90e4a3
(tcl-word-no-props): New function.
Tom Tromey <tromey@redhat.com>
parents:
12644
diff
changeset
|
1292 word)) |
3ce3ca90e4a3
(tcl-word-no-props): New function.
Tom Tromey <tromey@redhat.com>
parents:
12644
diff
changeset
|
1293 |
6709 | 1294 (defun tcl-current-word (flag) |
1295 "Return current command word, or nil. | |
1296 If FLAG is nil, just uses `current-word'. | |
1297 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
|
1298 (if (and flag |
1eb0d0f0f71b
tcl-current-word does the right thing in inferior-tcl-mode.
Tom Tromey <tromey@redhat.com>
parents:
7781
diff
changeset
|
1299 (memq major-mode '(tcl-mode inferior-tcl-mode))) |
6709 | 1300 (condition-case nil |
1301 (save-excursion | |
1302 ;; Look backward for first word actually in alist. | |
1303 (if (bobp) | |
1304 () | |
1305 (while (and (not (bobp)) | |
1306 (not (tcl-real-command-p))) | |
1307 (backward-sexp))) | |
12645
3ce3ca90e4a3
(tcl-word-no-props): New function.
Tom Tromey <tromey@redhat.com>
parents:
12644
diff
changeset
|
1308 (if (assoc (tcl-word-no-props) tcl-help-alist) |
3ce3ca90e4a3
(tcl-word-no-props): New function.
Tom Tromey <tromey@redhat.com>
parents:
12644
diff
changeset
|
1309 (tcl-word-no-props))) |
6709 | 1310 (error nil)) |
12645
3ce3ca90e4a3
(tcl-word-no-props): New function.
Tom Tromey <tromey@redhat.com>
parents:
12644
diff
changeset
|
1311 (tcl-word-no-props))) |
6709 | 1312 |
8252
7d4674a34de3
Added ";;;###autoload" comments where appropriate.
Tom Tromey <tromey@redhat.com>
parents:
7799
diff
changeset
|
1313 ;;;###autoload |
6709 | 1314 (defun tcl-help-on-word (command &optional arg) |
1315 "Get help on Tcl command. Default is word at point. | |
1316 Prefix argument means invert sense of `tcl-use-smart-word-finder'." | |
1317 (interactive | |
1318 (list | |
1319 (progn | |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1320 (if (not (equal tcl-help-directory-list tcl-help-saved-dirs)) |
6709 | 1321 (tcl-reread-help-files)) |
1322 (let ((word (tcl-current-word | |
1323 (if current-prefix-arg | |
1324 (not tcl-use-smart-word-finder) | |
1325 tcl-use-smart-word-finder)))) | |
1326 (completing-read | |
1327 (if (or (null word) (string= word "")) | |
1328 "Help on Tcl command: " | |
1329 (format "Help on Tcl command (default %s): " word)) | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1330 tcl-help-alist nil t nil nil word))) |
6709 | 1331 current-prefix-arg)) |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1332 (if (not (equal tcl-help-directory-list tcl-help-saved-dirs)) |
6709 | 1333 (tcl-reread-help-files)) |
1334 (if (string= command "") | |
1335 (setq command (tcl-current-word | |
1336 (if arg | |
1337 (not tcl-use-smart-word-finder) | |
1338 tcl-use-smart-word-finder)))) | |
1339 (let* ((help (get-buffer-create "*Tcl help*")) | |
1340 (cell (assoc command tcl-help-alist)) | |
1341 (file (and cell (cdr cell)))) | |
1342 (set-buffer help) | |
1343 (delete-region (point-min) (point-max)) | |
1344 (if file | |
1345 (progn | |
1346 (insert "*** " command "\n\n") | |
1347 (insert-file-contents file)) | |
1348 (if (string= command "") | |
1349 (insert "Magical Pig!") | |
1350 (insert "Tcl command " command " not in help\n"))) | |
1351 (set-buffer-modified-p nil) | |
1352 (goto-char (point-min)) | |
1353 (display-buffer help))) | |
1354 | |
1355 | |
1356 | |
1357 ;; | |
1358 ;; Other interactive stuff. | |
1359 ;; | |
1360 | |
1361 (defvar tcl-previous-dir/file nil | |
1362 "Record last directory and file used in loading. | |
1363 This holds a cons cell of the form `(DIRECTORY . FILE)' | |
1364 describing the last `tcl-load-file' command.") | |
1365 | |
1366 (defun tcl-load-file (file &optional and-go) | |
1367 "Load a Tcl file into the inferior Tcl process. | |
1368 Prefix argument means switch to the Tcl buffer afterwards." | |
1369 (interactive | |
1370 (list | |
1371 ;; car because comint-get-source returns a list holding the | |
1372 ;; filename. | |
8581
e7daed44da21
tcl-load-file default to current buffer.
Tom Tromey <tromey@redhat.com>
parents:
8580
diff
changeset
|
1373 (car (comint-get-source "Load Tcl file: " |
e7daed44da21
tcl-load-file default to current buffer.
Tom Tromey <tromey@redhat.com>
parents:
8580
diff
changeset
|
1374 (or (and |
e7daed44da21
tcl-load-file default to current buffer.
Tom Tromey <tromey@redhat.com>
parents:
8580
diff
changeset
|
1375 (eq major-mode 'tcl-mode) |
e7daed44da21
tcl-load-file default to current buffer.
Tom Tromey <tromey@redhat.com>
parents:
8580
diff
changeset
|
1376 (buffer-file-name)) |
e7daed44da21
tcl-load-file default to current buffer.
Tom Tromey <tromey@redhat.com>
parents:
8580
diff
changeset
|
1377 tcl-previous-dir/file) |
6709 | 1378 '(tcl-mode) t)) |
1379 current-prefix-arg)) | |
1380 (comint-check-source file) | |
1381 (setq tcl-previous-dir/file (cons (file-name-directory file) | |
1382 (file-name-nondirectory file))) | |
1383 (tcl-send-string (inferior-tcl-proc) | |
1384 (format inferior-tcl-source-command (tcl-quote file))) | |
1385 (if and-go (switch-to-tcl t))) | |
1386 | |
1387 (defun tcl-restart-with-file (file &optional and-go) | |
1388 "Restart inferior Tcl with file. | |
1389 If an inferior Tcl process exists, it is killed first. | |
1390 Prefix argument means switch to the Tcl buffer afterwards." | |
1391 (interactive | |
1392 (list | |
1393 (car (comint-get-source "Restart with Tcl file: " | |
1394 (or (and | |
1395 (eq major-mode 'tcl-mode) | |
1396 (buffer-file-name)) | |
1397 tcl-previous-dir/file) | |
1398 '(tcl-mode) t)) | |
1399 current-prefix-arg)) | |
1400 (let* ((buf (if (eq major-mode 'inferior-tcl-mode) | |
1401 (current-buffer) | |
1402 inferior-tcl-buffer)) | |
1403 (proc (and buf (get-process buf)))) | |
1404 (cond | |
1405 ((not (and buf (get-buffer buf))) | |
1406 ;; I think this will be ok. | |
1407 (inferior-tcl tcl-application) | |
1408 (tcl-load-file file and-go)) | |
1409 ((or | |
1410 (not (comint-check-proc buf)) | |
1411 (yes-or-no-p | |
1412 "A Tcl process is running, are you sure you want to reset it? ")) | |
1413 (save-excursion | |
1414 (comint-check-source file) | |
1415 (setq tcl-previous-dir/file (cons (file-name-directory file) | |
1416 (file-name-nondirectory file))) | |
1417 (comint-exec (get-buffer-create buf) | |
1418 (if proc | |
1419 (process-name proc) | |
1420 "inferior-tcl") | |
1421 tcl-application file tcl-command-switches) | |
1422 (if and-go (switch-to-tcl t))))))) | |
1423 | |
1424 (defun tcl-auto-fill-mode (&optional arg) | |
44320
40a69f39b79f
Change maintainer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44316
diff
changeset
|
1425 "Like `auto-fill-mode', but sets `comment-auto-fill-only-comments'." |
6709 | 1426 (interactive "P") |
44320
40a69f39b79f
Change maintainer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44316
diff
changeset
|
1427 (auto-fill-mode arg) |
40a69f39b79f
Change maintainer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44316
diff
changeset
|
1428 (if auto-fill-function |
40a69f39b79f
Change maintainer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44316
diff
changeset
|
1429 (set (make-local-variable 'comment-auto-fill-only-comments) t) |
40a69f39b79f
Change maintainer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44316
diff
changeset
|
1430 (kill-local-variable 'comment-auto-fill-only-comments))) |
6709 | 1431 |
1432 (defun tcl-electric-hash (&optional count) | |
1433 "Insert a `#' and quote if it does not start a real comment. | |
1434 Prefix arg is number of `#'s to insert. | |
1435 See variable `tcl-electric-hash-style' for description of quoting | |
1436 styles." | |
1437 (interactive "p") | |
1438 (or count (setq count 1)) | |
1439 (if (> count 0) | |
1440 (let ((type | |
1441 (if (eq tcl-electric-hash-style 'smart) | |
1442 (if (> count 3) ; FIXME what is "smart"? | |
1443 'quote | |
1444 'backslash) | |
1445 tcl-electric-hash-style)) | |
1446 comment) | |
1447 (if type | |
1448 (progn | |
1449 (save-excursion | |
1450 (insert "#") | |
1451 (setq comment (tcl-in-comment))) | |
1452 (delete-char 1) | |
1453 (and tcl-explain-indentation (message "comment: %s" comment)) | |
1454 (cond | |
1455 ((eq type 'quote) | |
1456 (if (not comment) | |
1457 (insert "\""))) | |
1458 ((eq type 'backslash) | |
1459 ;; The following will set count to 0, so the | |
1460 ;; insert-char can still be run. | |
1461 (if (not comment) | |
1462 (while (> count 0) | |
1463 (insert "\\#") | |
1464 (setq count (1- count))))) | |
1465 (t nil)))) | |
1466 (insert-char ?# count)))) | |
1467 | |
1468 (defun tcl-hashify-buffer () | |
1469 "Quote all `#'s in current buffer that aren't Tcl comments." | |
1470 (interactive) | |
1471 (save-excursion | |
1472 (goto-char (point-min)) | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1473 (let (state |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1474 result) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1475 (while (< (point) (point-max)) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1476 (setq result (tcl-hairy-scan-for-comment state (point-max) t)) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1477 (if (car result) |
6709 | 1478 (beginning-of-line 2) |
1479 (backward-char) | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1480 (if (eq ?# (following-char)) |
6709 | 1481 (insert "\\")) |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1482 (forward-char)) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1483 (setq state (cdr result)))))) |
6709 | 1484 |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1485 (defun tcl-comment-indent () |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1486 "Return the desired indentation, but be careful to add a `;' if needed." |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1487 (save-excursion |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1488 ;; If line is not blank, make sure we insert a ";" first. |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1489 (skip-chars-backward " \t") |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1490 (unless (or (bolp) (tcl-real-command-p)) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1491 (insert ";") |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1492 ;; Try and erase a non-significant char to keep charpos identical. |
64053
fd24f2ae0e10
(tcl): Finish `defgroup' description with period.
Juanma Barranquero <lekktu@gmail.com>
parents:
62531
diff
changeset
|
1493 (if (memq (char-after) '(?\t ?\s)) (delete-char 1)))) |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1494 (funcall (default-value 'comment-indent-function))) |
7052
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1495 |
6709 | 1496 ;; The following was inspired by the Tcl editing mode written by |
1497 ;; Gregor Schmid <schmid@fb3-s7.math.TU-Berlin.DE>. His version also | |
1498 ;; attempts to snarf the command line options from the command line, | |
1499 ;; but I didn't think that would really be that helpful (doesn't seem | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1500 ;; like it would be right enough. His version also looks for the |
6709 | 1501 ;; "#!/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
|
1502 ;; FIXME should make sure that the application mentioned actually |
5dfd509b6396
Wrote tcl-indent-for-comment
Tom Tromey <tromey@redhat.com>
parents:
6730
diff
changeset
|
1503 ;; exists. |
6709 | 1504 (defun tcl-guess-application () |
1505 "Attempt to guess Tcl application by looking at first line. | |
1506 The first line is assumed to look like \"#!.../program ...\"." | |
1507 (save-excursion | |
1508 (goto-char (point-min)) | |
8580
648f78c8ecf5
Fixed bug in tcl-guess-application.
Tom Tromey <tromey@redhat.com>
parents:
8575
diff
changeset
|
1509 (if (looking-at "#![^ \t]*/\\([^ \t\n/]+\\)\\([ \t]\\|$\\)") |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1510 (set (make-local-variable 'tcl-application) (match-string 1))))) |
6709 | 1511 |
1512 | |
1513 | |
1514 ;; | |
11787
635f5fb5d82a
Changed "Lucid Emacs" to "XEmacs".
Tom Tromey <tromey@redhat.com>
parents:
11303
diff
changeset
|
1515 ;; XEmacs menu support. |
6709 | 1516 ;; Taken from schmid@fb3-s7.math.TU-Berlin.DE (Gregor Schmid), |
1517 ;; who wrote a different Tcl mode. | |
25163 | 1518 ;; We also have support for menus in Emacs. We do this by |
11787
635f5fb5d82a
Changed "Lucid Emacs" to "XEmacs".
Tom Tromey <tromey@redhat.com>
parents:
11303
diff
changeset
|
1519 ;; loading the XEmacs menu emulation code. |
6709 | 1520 ;; |
1521 | |
1522 (defun tcl-popup-menu (e) | |
7612 | 1523 (interactive "@e") |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1524 (popup-menu tcl-mode-menu)) |
6709 | 1525 |
1526 | |
1527 | |
1528 ;; | |
1529 ;; Quoting and unquoting functions. | |
1530 ;; | |
1531 | |
1532 ;; This quoting is sufficient to protect eg a filename from any sort | |
1533 ;; of expansion or splitting. Tcl quoting sure sucks. | |
1534 (defun tcl-quote (string) | |
1535 "Quote STRING according to Tcl rules." | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1536 (mapconcat (lambda (char) |
64053
fd24f2ae0e10
(tcl): Finish `defgroup' description with period.
Juanma Barranquero <lekktu@gmail.com>
parents:
62531
diff
changeset
|
1537 (if (memq char '(?[ ?] ?{ ?} ?\\ ?\" ?$ ?\s ?\;)) |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1538 (concat "\\" (char-to-string char)) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1539 (char-to-string char))) |
6709 | 1540 string "")) |
1541 | |
7628 | 1542 ;; |
1543 ;; Bug reporting. | |
1544 ;; | |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1545 |
7628 | 1546 |
39754
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1547 ;; These are relics kept "just in case". |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1548 (defalias 'tcl-uncomment-region 'uncomment-region) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1549 (defalias 'tcl-indent-for-comment 'comment-indent) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1550 (defalias 'add-log-tcl-defun 'tcl-add-log-defun) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1551 (defalias 'indent-tcl-exp 'tcl-indent-exp) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1552 (defalias 'calculate-tcl-indent 'tcl-calculate-indent) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1553 (defalias 'tcl-beginning-of-defun 'beginning-of-defun) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1554 (defalias 'tcl-end-of-defun 'end-of-defun) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1555 (defalias 'tcl-mark-defun 'mark-defun) |
6a46751c85df
Change maintainer to FSF and remove loads of compatibility cruft.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
38476
diff
changeset
|
1556 (defun tcl-mark () (mark t)) |
7628 | 1557 |
6709 | 1558 (provide 'tcl) |
1559 | |
61246
ee782d6579a8
(tcl-set-font-lock-keywords): Use new \_< ops.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58563
diff
changeset
|
1560 ;; arch-tag: 8a032554-c3ef-422e-b84c-acec0522179d |
6709 | 1561 ;;; tcl.el ends here |