Mercurial > emacs
annotate lisp/skeleton.el @ 15491:ea6697d31d1c
(term-exec-1): Run process on pty if possible.
author | Richard M. Stallman <rms@gnu.org> |
---|---|
date | Sun, 23 Jun 1996 15:51:57 +0000 |
parents | 5393431269db |
children | 1a66dbb1a470 |
rev | line source |
---|---|
12501 | 1 ;;; skeleton.el --- Lisp language extension for writing statement skeletons |
14169 | 2 |
15489
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
3 ;; Copyright (C) 1993, 1994, 1995, 1996 by Free Software Foundation, Inc. |
6463 | 4 |
12501 | 5 ;; Author: Daniel.Pfeiffer@Informatik.START.dbp.de, fax (+49 69) 7588-2389 |
6463 | 6 ;; Maintainer: FSF |
12501 | 7 ;; Keywords: extensions, abbrev, languages, tools |
6463 | 8 |
9 ;; This file is part of GNU Emacs. | |
10 | |
11 ;; GNU Emacs is free software; you can redistribute it and/or modify | |
12 ;; it under the terms of the GNU General Public License as published by | |
13 ;; the Free Software Foundation; either version 2, or (at your option) | |
14 ;; any later version. | |
15 | |
16 ;; GNU Emacs is distributed in the hope that it will be useful, | |
17 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
19 ;; GNU General Public License for more details. | |
20 | |
21 ;; You should have received a copy of the GNU General Public License | |
14169 | 22 ;; along with GNU Emacs; see the file COPYING. If not, write to the |
23 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330, | |
24 ;; Boston, MA 02111-1307, USA. | |
6463 | 25 |
26 ;;; Commentary: | |
27 | |
12501 | 28 ;; A very concise language extension for writing structured statement |
6463 | 29 ;; skeleton insertion commands for programming language modes. This |
30 ;; originated in shell-script mode and was applied to ada-mode's | |
31 ;; commands which shrunk to one third. And these commands are now | |
32 ;; user configurable. | |
33 | |
34 ;;; Code: | |
35 | |
12501 | 36 ;; page 1: statement skeleton language definition & interpreter |
6463 | 37 ;; page 2: paired insertion |
38 ;; page 3: mirror-mode, an example for setting up paired insertion | |
39 | |
40 | |
41 (defvar skeleton-transformation nil | |
12501 | 42 "*If non-nil, function applied to literal strings before they are inserted. |
6463 | 43 It should take strings and characters and return them transformed, or nil |
44 which means no transformation. | |
45 Typical examples might be `upcase' or `capitalize'.") | |
46 | |
47 ; this should be a fourth argument to defvar | |
48 (put 'skeleton-transformation 'variable-interactive | |
49 "aTransformation function: ") | |
50 | |
51 | |
15489
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
52 (defvar skeleton-autowrap t |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
53 "Controls wrapping behaviour of functions created with `define-skeleton'. |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
54 When the region is visible (due to `transient-mark-mode' or marking a region |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
55 with the mouse) and this is non-`nil' and the function was called without an |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
56 explicit ARG, then the ARG defaults to -1, i.e. wrapping around the visible |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
57 region. |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
58 |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
59 We will probably delete this variable in a future Emacs version |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
60 unless we get a substantial number of complaints about the auto-wrap |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
61 feature.") |
6463 | 62 |
13390
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
63 (defvar skeleton-end-hook |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
64 (lambda () |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
65 (or (eolp) (newline-and-indent))) |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
66 "Hook called at end of skeleton but before going to point of interest. |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
67 By default this moves out anything following to next line. |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
68 The variables `v1' and `v2' are still set when calling this.") |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
69 |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
70 |
12501 | 71 ;;;###autoload |
72 (defvar skeleton-filter 'identity | |
15489
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
73 "Function for transforming a skeleton proxy's aliases' variable value.") |
12501 | 74 |
75 (defvar skeleton-untabify t | |
76 "When non-`nil' untabifies when deleting backwards with element -ARG.") | |
77 | |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
78 (defvar skeleton-newline-indent-rigidly nil |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
79 "When non-`nil', indent rigidly under current line for element `\\n'. |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
80 Else use mode's `indent-line-function'.") |
12501 | 81 |
82 (defvar skeleton-further-elements () | |
83 "A buffer-local varlist (see `let') of mode specific skeleton elements. | |
84 These variables are bound while interpreting a skeleton. Their value may | |
85 in turn be any valid skeleton element if they are themselves to be used as | |
86 skeleton elements.") | |
87 (make-variable-buffer-local 'skeleton-further-elements) | |
88 | |
89 | |
6463 | 90 (defvar skeleton-subprompt |
91 (substitute-command-keys | |
92 "RET, \\<minibuffer-local-map>\\[abort-recursive-edit] or \\[help-command]") | |
12501 | 93 "*Replacement for %s in prompts of recursive subskeletons.") |
6463 | 94 |
95 | |
15489
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
96 (defvar skeleton-abbrev-cleanup nil |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
97 "Variable used to delete the character that led to abbrev expansion.") |
12501 | 98 |
6463 | 99 |
100 (defvar skeleton-debug nil | |
101 "*If non-nil `define-skeleton' will override previous definition.") | |
102 | |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
103 ;; reduce the number of compiler warnings |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
104 (defvar skeleton) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
105 (defvar skeleton-modified) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
106 (defvar skeleton-point) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
107 (defvar skeleton-regions) |
6463 | 108 |
109 ;;;###autoload | |
12501 | 110 (defmacro define-skeleton (command documentation &rest skeleton) |
6463 | 111 "Define a user-configurable COMMAND that enters a statement skeleton. |
112 DOCUMENTATION is that of the command, while the variable of the same name, | |
12501 | 113 which contains the skeleton, has a documentation to that effect. |
114 INTERACTOR and ELEMENT ... are as defined under `skeleton-insert'." | |
6463 | 115 (if skeleton-debug |
12501 | 116 (set command skeleton)) |
12862
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
117 `(progn |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
118 (defvar ,command ',skeleton ,documentation) |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
119 (defalias ',command 'skeleton-proxy))) |
6463 | 120 |
121 | |
122 | |
12501 | 123 ;; This command isn't meant to be called, only it's aliases with meaningful |
124 ;; names are. | |
6463 | 125 ;;;###autoload |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
126 (defun skeleton-proxy (&optional str arg) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
127 "Insert skeleton defined by variable of same name (see `skeleton-insert'). |
12501 | 128 Prefix ARG allows wrapping around words or regions (see `skeleton-insert'). |
15489
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
129 If no ARG was given, and the region is visible, it defaults to -1 depending |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
130 on `skeleton-autowrap'. An ARG of M-0 will prevent this just for once. |
12501 | 131 This command can also be an abbrev expansion (3rd and 4th columns in |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
132 \\[edit-abbrevs] buffer: \"\" command-name). |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
133 |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
134 When called as a function, optional first argument STR may also be a string |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
135 which will be the value of `str' whereas the skeleton's interactor is then |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
136 ignored." |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
137 (interactive "*P\nP") |
12501 | 138 (let ((function (nth 1 (backtrace-frame 1)))) |
15489
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
139 (if (eq function 'nth) ; uncompiled Lisp function |
12501 | 140 (setq function (nth 1 (backtrace-frame 5))) |
141 (if (eq function 'byte-code) ; tracing byte-compiled function | |
142 (setq function (nth 1 (backtrace-frame 2))))) | |
143 (if (not (setq function (funcall skeleton-filter (symbol-value function)))) | |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
144 (if (memq this-command '(self-insert-command |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
145 skeleton-pair-insert-maybe |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
146 expand-abbrev)) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
147 (setq buffer-undo-list (primitive-undo 1 buffer-undo-list))) |
12501 | 148 (skeleton-insert function |
149 (if (setq skeleton-abbrev-cleanup | |
150 (or (eq this-command 'self-insert-command) | |
13390
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
151 (eq this-command |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
152 'skeleton-pair-insert-maybe))) |
12501 | 153 () |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
154 ;; Pretend C-x a e passed its prefix arg to us |
12501 | 155 (if (or arg current-prefix-arg) |
156 (prefix-numeric-value (or arg | |
15489
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
157 current-prefix-arg)) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
158 (and skeleton-autowrap |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
159 (or (eq last-command 'mouse-drag-region) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
160 (and transient-mark-mode mark-active)) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
161 -1))) |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
162 (if (stringp str) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
163 str)) |
15489
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
164 (and skeleton-abbrev-cleanup |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
165 (setq skeleton-abbrev-cleanup (point)) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
166 (add-hook 'post-command-hook 'skeleton-abbrev-cleanup nil t))))) |
12501 | 167 |
168 | |
169 (defun skeleton-abbrev-cleanup (&rest list) | |
170 "Value for `post-command-hook' to remove char that expanded abbrev." | |
171 (if (integerp skeleton-abbrev-cleanup) | |
172 (progn | |
173 (delete-region skeleton-abbrev-cleanup (point)) | |
15489
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
174 (setq skeleton-abbrev-cleanup) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
175 (remove-hook 'post-command-hook 'skeleton-abbrev-cleanup t)))) |
12501 | 176 |
177 | |
178 ;;;###autoload | |
13390
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
179 (defun skeleton-insert (skeleton &optional skeleton-regions str) |
12501 | 180 "Insert the complex statement skeleton SKELETON describes very concisely. |
6463 | 181 |
12501 | 182 With optional third REGIONS wrap first interesting point (`_') in skeleton |
183 around next REGIONS words, if REGIONS is positive. If REGIONS is negative, | |
184 wrap REGIONS preceding interregions into first REGIONS interesting positions | |
185 \(successive `_'s) in skeleton. An interregion is the stretch of text between | |
186 two contiguous marked points. If you marked A B C [] (where [] is the cursor) | |
187 in alphabetical order, the 3 interregions are simply the last 3 regions. But | |
188 if you marked B A [] C, the interregions are B-A, A-[], []-C. | |
189 | |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
190 Optional fourth STR is the value for the variable `str' within the skeleton. |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
191 When this is non-`nil' the interactor gets ignored, and this should be a valid |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
192 skeleton element. |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
193 |
12501 | 194 SKELETON is made up as (INTERACTOR ELEMENT ...). INTERACTOR may be nil if |
195 not needed, a prompt-string or an expression for complex read functions. | |
6463 | 196 |
197 If ELEMENT is a string or a character it gets inserted (see also | |
198 `skeleton-transformation'). Other possibilities are: | |
199 | |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
200 \\n go to next line and indent according to mode |
12501 | 201 _ interesting point, interregion here, point after termination |
202 > indent line (or interregion if > _) according to major mode | |
203 & do next ELEMENT if previous moved point | |
204 | do next ELEMENT if previous didn't move point | |
205 -num delete num preceding characters (see `skeleton-untabify') | |
6463 | 206 resume: skipped, continue here if quit is signaled |
207 nil skipped | |
208 | |
12501 | 209 Further elements can be defined via `skeleton-further-elements'. ELEMENT may |
210 itself be a SKELETON with an INTERACTOR. The user is prompted repeatedly for | |
211 different inputs. The SKELETON is processed as often as the user enters a | |
212 non-empty string. \\[keyboard-quit] terminates skeleton insertion, but | |
213 continues after `resume:' and positions at `_' if any. If INTERACTOR in such | |
214 a subskeleton is a prompt-string which contains a \".. %s ..\" it is | |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
215 formatted with `skeleton-subprompt'. Such an INTERACTOR may also a list of |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
216 strings with the subskeleton being repeated once for each string. |
6463 | 217 |
15489
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
218 Quoted Lisp expressions are evaluated evaluated for their side-effect. |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
219 Other Lisp expressions are evaluated and the value treated as above. |
14006 | 220 Note that expressions may not return `t' since this implies an |
12501 | 221 endless loop. Modes can define other symbols by locally setting them |
222 to any valid skeleton element. The following local variables are | |
223 available: | |
6463 | 224 |
12501 | 225 str first time: read a string according to INTERACTOR |
6463 | 226 then: insert previously read string once more |
12501 | 227 help help-form during interaction with the user or `nil' |
12862
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
228 input initial input (string or cons with index) while reading str |
15489
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
229 v1, v2 local variables for memorizing anything you want |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
230 |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
231 When done with skeleton, but before going back to `_'-point call |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
232 `skeleton-end-hook' if that is non-`nil'." |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
233 (and skeleton-regions |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
234 (setq skeleton-regions |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
235 (if (> skeleton-regions 0) |
12501 | 236 (list (point-marker) |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
237 (save-excursion (forward-word skeleton-regions) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
238 (point-marker))) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
239 (setq skeleton-regions (- skeleton-regions)) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
240 ;; copy skeleton-regions - 1 elements from `mark-ring' |
12501 | 241 (let ((l1 (cons (mark-marker) mark-ring)) |
242 (l2 (list (point-marker)))) | |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
243 (while (and l1 (> skeleton-regions 0)) |
12501 | 244 (setq l2 (cons (car l1) l2) |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
245 skeleton-regions (1- skeleton-regions) |
12501 | 246 l1 (cdr l1))) |
247 (sort l2 '<)))) | |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
248 (goto-char (car skeleton-regions)) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
249 (setq skeleton-regions (cdr skeleton-regions))) |
12862
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
250 (let ((beg (point)) |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
251 skeleton-modified skeleton-point resume: help input v1 v2) |
12501 | 252 (unwind-protect |
12862
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
253 (eval `(let ,skeleton-further-elements |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
254 (skeleton-internal-list skeleton str))) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
255 (run-hooks 'skeleton-end-hook) |
12862
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
256 (sit-for 0) |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
257 (or (pos-visible-in-window-p beg) |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
258 (progn |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
259 (goto-char beg) |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
260 (recenter 0))) |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
261 (if skeleton-point |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
262 (goto-char skeleton-point))))) |
6463 | 263 |
12501 | 264 (defun skeleton-read (str &optional initial-input recursive) |
12862
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
265 "Function for reading a string from the minibuffer within skeletons. |
12501 | 266 PROMPT may contain a `%s' which will be replaced by `skeleton-subprompt'. |
12862
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
267 If non-`nil' second arg INITIAL-INPUT or variable `input' is a string or |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
268 cons with index to insert before reading. If third arg RECURSIVE is non-`nil' |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
269 i.e. we are handling the iterator of a subskeleton, returns empty string if |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
270 user didn't modify input. |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
271 While reading, the value of `minibuffer-help-form' is variable `help' if that |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
272 is non-`nil' or a default string." |
13390
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
273 (let ((minibuffer-help-form (or (if (boundp 'help) (symbol-value 'help)) |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
274 (if recursive "\ |
6463 | 275 As long as you provide input you will insert another subskeleton. |
276 | |
277 If you enter the empty string, the loop inserting subskeletons is | |
278 left, and the current one is removed as far as it has been entered. | |
279 | |
280 If you quit, the current subskeleton is removed as far as it has been | |
281 entered. No more of the skeleton will be inserted, except maybe for a | |
12501 | 282 syntactically necessary termination." |
12862
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
283 "\ |
12501 | 284 You are inserting a skeleton. Standard text gets inserted into the buffer |
13390
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
285 automatically, and you are prompted to fill in the variable parts."))) |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
286 (eolp (eolp))) |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
287 ;; since Emacs doesn't show main window's cursor, do something noticeable |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
288 (or eolp |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
289 (open-line 1)) |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
290 (unwind-protect |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
291 (setq str (if (stringp str) |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
292 (read-string (format str skeleton-subprompt) |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
293 (setq initial-input |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
294 (or initial-input |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
295 (symbol-value 'input)))) |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
296 (eval str))) |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
297 (or eolp |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
298 (delete-char 1)))) |
12862
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
299 (if (and recursive |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
300 (or (null str) |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
301 (string= str "") |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
302 (equal str initial-input) |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
303 (equal str (car-safe initial-input)))) |
6463 | 304 (signal 'quit t) |
305 str)) | |
306 | |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
307 (defun skeleton-internal-list (skeleton &optional str recursive) |
12501 | 308 (let* ((start (save-excursion (beginning-of-line) (point))) |
309 (column (current-column)) | |
310 (line (buffer-substring start | |
311 (save-excursion (end-of-line) (point)))) | |
312 opoint) | |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
313 (or str |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
314 (setq str `(setq str (skeleton-read ',(car skeleton) nil ,recursive)))) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
315 (while (setq skeleton-modified (eq opoint (point)) |
12862
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
316 opoint (point) |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
317 skeleton (cdr skeleton)) |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
318 (condition-case quit |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
319 (skeleton-internal-1 (car skeleton)) |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
320 (quit |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
321 (if (eq (cdr quit) 'recursive) |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
322 (setq recursive 'quit |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
323 skeleton (memq 'resume: skeleton)) |
12862
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
324 ;; remove the subskeleton as far as it has been shown |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
325 ;; the subskeleton shouldn't have deleted outside current line |
13390
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
326 (end-of-line) |
12862
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
327 (delete-region start (point)) |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
328 (insert line) |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
329 (move-to-column column) |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
330 (if (cdr quit) |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
331 (setq skeleton () |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
332 recursive nil) |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
333 (signal 'quit 'recursive))))))) |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
334 ;; maybe continue loop or go on to next outer resume: section |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
335 (if (eq recursive 'quit) |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
336 (signal 'quit 'recursive) |
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
337 recursive)) |
6463 | 338 |
339 | |
12501 | 340 (defun skeleton-internal-1 (element &optional literal) |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
341 (cond ((char-or-string-p element) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
342 (if (and (integerp element) ; -num |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
343 (< element 0)) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
344 (if skeleton-untabify |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
345 (backward-delete-char-untabify (- element)) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
346 (delete-backward-char (- element))) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
347 (insert-before-markers (if (and skeleton-transformation |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
348 (not literal)) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
349 (funcall skeleton-transformation element) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
350 element)))) |
7393
e4a565cee722
(mirror-mode): Commented out.
Richard M. Stallman <rms@gnu.org>
parents:
6463
diff
changeset
|
351 ((eq element '\n) ; actually (eq '\n 'n) |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
352 (if (and skeleton-regions |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
353 (eq (nth 1 skeleton) '_)) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
354 (progn |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
355 (or (eolp) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
356 (newline)) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
357 (indent-region (point) (car skeleton-regions) nil)) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
358 (if skeleton-newline-indent-rigidly |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
359 (indent-to (prog1 (current-indentation) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
360 (newline))) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
361 (newline) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
362 (indent-according-to-mode)))) |
7393
e4a565cee722
(mirror-mode): Commented out.
Richard M. Stallman <rms@gnu.org>
parents:
6463
diff
changeset
|
363 ((eq element '>) |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
364 (if (and skeleton-regions |
12501 | 365 (eq (nth 1 skeleton) '_)) |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
366 (indent-region (point) (car skeleton-regions) nil) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
367 (indent-according-to-mode))) |
7393
e4a565cee722
(mirror-mode): Commented out.
Richard M. Stallman <rms@gnu.org>
parents:
6463
diff
changeset
|
368 ((eq element '_) |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
369 (if skeleton-regions |
12501 | 370 (progn |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
371 (goto-char (car skeleton-regions)) |
13390
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
372 (setq skeleton-regions (cdr skeleton-regions)) |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
373 (and (<= (current-column) (current-indentation)) |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
374 (eq (nth 1 skeleton) '\n) |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
375 (end-of-line 0))) |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
376 (or skeleton-point |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
377 (setq skeleton-point (point))))) |
7393
e4a565cee722
(mirror-mode): Commented out.
Richard M. Stallman <rms@gnu.org>
parents:
6463
diff
changeset
|
378 ((eq element '&) |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
379 (if skeleton-modified |
12501 | 380 (setq skeleton (cdr skeleton)))) |
7393
e4a565cee722
(mirror-mode): Commented out.
Richard M. Stallman <rms@gnu.org>
parents:
6463
diff
changeset
|
381 ((eq element '|) |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
382 (or skeleton-modified |
12501 | 383 (setq skeleton (cdr skeleton)))) |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
384 ((eq 'quote (car-safe element)) |
12501 | 385 (eval (nth 1 element))) |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
386 ((or (stringp (car-safe element)) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
387 (consp (car-safe element))) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
388 (if (symbolp (car-safe (car element))) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
389 (while (skeleton-internal-list element nil t)) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
390 (setq literal (car element)) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
391 (while literal |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
392 (skeleton-internal-list element (car literal)) |
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
393 (setq literal (cdr literal))))) |
12501 | 394 ((null element)) |
395 ((skeleton-internal-1 (eval element) t)))) | |
396 | |
12886
4029ded28f9d
(skeleton-newline-indent-rigidly): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
12862
diff
changeset
|
397 |
12501 | 398 ;; Maybe belongs into simple.el or elsewhere |
6463 | 399 |
15441
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
400 ;;;(define-skeleton local-variables-section |
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
401 ;;; "Insert a local variables section. Use current comment syntax if any." |
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
402 ;;; (completing-read "Mode: " obarray |
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
403 ;;; (lambda (symbol) |
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
404 ;;; (if (commandp symbol) |
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
405 ;;; (string-match "-mode$" (symbol-name symbol)))) |
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
406 ;;; t) |
15489
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
407 ;;; '(save-excursion |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
408 ;;; (if (re-search-forward page-delimiter nil t) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
409 ;;; (error "Not on last page."))) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
410 ;;; comment-start "Local Variables:" comment-end \n |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
411 ;;; comment-start "mode: " str |
15441
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
412 ;;; & -5 | '(kill-line 0) & -1 | comment-end \n |
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
413 ;;; ( (completing-read (format "Variable, %s: " skeleton-subprompt) |
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
414 ;;; obarray |
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
415 ;;; (lambda (symbol) |
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
416 ;;; (or (eq symbol 'eval) |
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
417 ;;; (user-variable-p symbol))) |
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
418 ;;; t) |
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
419 ;;; comment-start str ": " |
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
420 ;;; (read-from-minibuffer "Expression: " nil read-expression-map nil |
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
421 ;;; 'read-expression-history) | _ |
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
422 ;;; comment-end \n) |
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
423 ;;; resume: |
4b82998394ae
(local-variables-section): Deleted.
Richard M. Stallman <rms@gnu.org>
parents:
14724
diff
changeset
|
424 ;;; comment-start "End:" comment-end) |
6463 | 425 |
12619
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
426 ;; Variables and command for automatically inserting pairs like () or "". |
6463 | 427 |
12619
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
428 (defvar skeleton-pair nil |
6463 | 429 "*If this is nil pairing is turned off, no matter what else is set. |
12619
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
430 Otherwise modes with `skeleton-pair-insert-maybe' on some keys |
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
431 will attempt to insert pairs of matching characters.") |
6463 | 432 |
433 | |
12619
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
434 (defvar skeleton-pair-on-word nil |
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
435 "*If this is nil, paired insertion is inhibited before or inside a word.") |
6463 | 436 |
437 | |
12619
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
438 (defvar skeleton-pair-filter (lambda ()) |
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
439 "Attempt paired insertion if this function returns nil, before inserting. |
6463 | 440 This allows for context-sensitive checking whether pairing is appropriate.") |
441 | |
442 | |
12619
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
443 (defvar skeleton-pair-alist () |
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
444 "An override alist of pairing partners matched against `last-command-char'. |
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
445 Each alist element, which looks like (ELEMENT ...), is passed to |
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
446 `skeleton-insert' with no interactor. Variable `str' does nothing. |
6463 | 447 |
12501 | 448 Elements might be (?` ?` _ \"''\"), (?\\( ? _ \" )\") or (?{ \\n > _ \\n ?} >).") |
6463 | 449 |
450 | |
451 ;;;###autoload | |
12619
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
452 (defun skeleton-pair-insert-maybe (arg) |
6463 | 453 "Insert the character you type ARG times. |
454 | |
12619
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
455 With no ARG, if `skeleton-pair' is non-nil, and if |
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
456 `skeleton-pair-on-word' is non-nil or we are not before or inside a |
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
457 word, and if `skeleton-pair-filter' returns nil, pairing is performed. |
6463 | 458 |
12619
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
459 If a match is found in `skeleton-pair-alist', that is inserted, else |
6463 | 460 the defaults are used. These are (), [], {}, <> and `' for the |
461 symmetrical ones, and the same character twice for the others." | |
462 (interactive "*P") | |
463 (if (or arg | |
12862
9d994b0faaa3
(skeleton-pair-insert-maybe): Plain insert in Ovwrt mode
Karl Heuer <kwzh@gnu.org>
parents:
12619
diff
changeset
|
464 overwrite-mode |
12619
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
465 (not skeleton-pair) |
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
466 (if (not skeleton-pair-on-word) (looking-at "\\w")) |
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
467 (funcall skeleton-pair-filter)) |
6463 | 468 (self-insert-command (prefix-numeric-value arg)) |
12501 | 469 (self-insert-command 1) |
470 (if skeleton-abbrev-cleanup | |
471 () | |
472 ;; (preceding-char) is stripped of any Meta-stuff in last-command-char | |
12619
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
473 (if (setq arg (assq (preceding-char) skeleton-pair-alist)) |
13390
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
474 ;; typed char is inserted (car is no real interactor) |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
475 (let (skeleton-end-hook) |
333a77bb4ae8
(skeleton-end-hook): Now defvared and responsible for
Karl Heuer <kwzh@gnu.org>
parents:
12886
diff
changeset
|
476 (skeleton-insert arg)) |
12501 | 477 (save-excursion |
478 (insert (or (cdr (assq (preceding-char) | |
479 '((?( . ?)) | |
480 (?[ . ?]) | |
481 (?{ . ?}) | |
482 (?< . ?>) | |
483 (?` . ?')))) | |
484 last-command-char))))))) | |
6463 | 485 |
486 | |
15489
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
487 ;;; A more serious example can be found in sh-script.el |
12619
9d4a4e914215
(local-variables-section): Delete autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents:
12501
diff
changeset
|
488 ;;;(defun mirror-mode () |
15489
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
489 ;; "This major mode is an amusing little example of paired insertion. |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
490 ;;All printable characters do a paired self insert, while the other commands |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
491 ;;work normally." |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
492 ;; (interactive) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
493 ;; (kill-all-local-variables) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
494 ;; (make-local-variable 'pair) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
495 ;; (make-local-variable 'pair-on-word) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
496 ;; (make-local-variable 'pair-filter) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
497 ;; (make-local-variable 'pair-alist) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
498 ;; (setq major-mode 'mirror-mode |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
499 ;; mode-name "Mirror" |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
500 ;; pair-on-word t |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
501 ;; ;; in the middle column insert one or none if odd window-width |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
502 ;; pair-filter (lambda () |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
503 ;; (if (>= (current-column) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
504 ;; (/ (window-width) 2)) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
505 ;; ;; insert both on next line |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
506 ;; (next-line 1) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
507 ;; ;; insert one or both? |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
508 ;; (= (* 2 (1+ (current-column))) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
509 ;; (window-width)))) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
510 ;; ;; mirror these the other way round as well |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
511 ;; pair-alist '((?) _ ?() |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
512 ;; (?] _ ?[) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
513 ;; (?} _ ?{) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
514 ;; (?> _ ?<) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
515 ;; (?/ _ ?\\) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
516 ;; (?\\ _ ?/) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
517 ;; (?` ?` _ "''") |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
518 ;; (?' ?' _ "``")) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
519 ;; ;; in this mode we exceptionally ignore the user, else it's no fun |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
520 ;; pair t) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
521 ;; (let ((map (make-keymap)) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
522 ;; (i ? )) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
523 ;; (use-local-map map) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
524 ;; (setq map (car (cdr map))) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
525 ;; (while (< i ?\^?) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
526 ;; (aset map i 'skeleton-pair-insert-maybe) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
527 ;; (setq i (1+ i)))) |
5393431269db
(skeleton-autowrap): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
15441
diff
changeset
|
528 ;; (run-hooks 'mirror-mode-hook)) |
6463 | 529 |
14724 | 530 (provide 'skeleton) |
531 | |
6463 | 532 ;; skeleton.el ends here |