summaryrefslogtreecommitdiff
path: root/lisp/skeleton.el
diff options
context:
space:
mode:
authorRichard M. Stallman <rms@gnu.org>1994-05-07 05:30:31 +0000
committerRichard M. Stallman <rms@gnu.org>1994-05-07 05:30:31 +0000
commitc93d212ae5a38032aa974b62821b77af58c43f95 (patch)
tree83a38da3133d466055e89992f0ebcab0756dc728 /lisp/skeleton.el
parent6803ec2a28d09e22f4b8974ed65c4d08202fd9ce (diff)
downloademacs-c93d212ae5a38032aa974b62821b77af58c43f95.tar.gz
(mirror-mode): Commented out.
Diffstat (limited to 'lisp/skeleton.el')
-rw-r--r--lisp/skeleton.el142
1 files changed, 70 insertions, 72 deletions
diff --git a/lisp/skeleton.el b/lisp/skeleton.el
index 548644f0fe4..38cc8d3cdc9 100644
--- a/lisp/skeleton.el
+++ b/lisp/skeleton.el
@@ -192,35 +192,35 @@ syntactically necessary termination."))
(defun skeleton-internal-1 (element)
- (cond ( (and (integerp element)
- (< element 0))
- (delete-char element))
- ( (char-or-string-p element)
- (insert (if skeleton-transformation
- (funcall skeleton-transformation element)
- element)) )
- ( (eq element '\n) ; actually (eq '\n 'n)
- (newline)
- (indent-relative t) )
- ( (eq element '>)
- (indent-for-tab-command) )
- ( (eq element '<)
- (backward-delete-char-untabify (min tab-width (current-column))) )
- ( (eq element '_)
- (or point
- (setq point (point))) )
- ( (eq element '&)
- (if modified
- (setq definition (cdr definition))) )
- ( (eq element '|)
- (or modified
- (setq definition (cdr definition))) )
- ( (if (consp element)
- (or (stringp (car element))
- (consp (car element))))
- (while (skeleton-internal-list element (car element) t)) )
- ( (null element) )
- ( (skeleton-internal-1 (eval element)) )))
+ (cond ((and (integerp element)
+ (< element 0))
+ (delete-char element))
+ ((char-or-string-p element)
+ (insert (if skeleton-transformation
+ (funcall skeleton-transformation element)
+ element)) )
+ ((eq element '\n) ; actually (eq '\n 'n)
+ (newline)
+ (indent-relative t) )
+ ((eq element '>)
+ (indent-for-tab-command) )
+ ((eq element '<)
+ (backward-delete-char-untabify (min tab-width (current-column))) )
+ ((eq element '_)
+ (or point
+ (setq point (point))) )
+ ((eq element '&)
+ (if modified
+ (setq definition (cdr definition))) )
+ ((eq element '|)
+ (or modified
+ (setq definition (cdr definition))) )
+ ((if (consp element)
+ (or (stringp (car element))
+ (consp (car element))))
+ (while (skeleton-internal-list element (car element) t)) )
+ ((null element) )
+ ((skeleton-internal-1 (eval element)) )))
;; variables and command for automatically inserting pairs like () or ""
@@ -280,49 +280,47 @@ symmetrical ones, and the same character twice for the others."
last-command-char))))))
-
-;;;###autoload
;; a more serious example can be found in shell-script.el
-(defun mirror-mode ()
- "This major mode is an amusing little example of paired insertion.
-All printable characters do a paired self insert, while the other commands
-work normally."
- (interactive)
- (kill-all-local-variables)
- (make-local-variable 'pair)
- (make-local-variable 'pair-on-word)
- (make-local-variable 'pair-filter)
- (make-local-variable 'pair-alist)
- (setq major-mode 'mirror-mode
- mode-name "Mirror"
- pair-on-word t
- ;; in the middle column insert one or none if odd window-width
- pair-filter (lambda ()
- (if (>= (current-column)
- (/ (window-width) 2))
- ;; insert both on next line
- (next-line 1)
- ;; insert one or both?
- (= (* 2 (1+ (current-column)))
- (window-width))))
- ;; mirror these the other way round as well
- pair-alist '((?) _ ?()
- (?] _ ?[)
- (?} _ ?{)
- (?> _ ?<)
- (?/ _ ?\\)
- (?\\ _ ?/)
- (?` ?` _ "''")
- (?' ?' _ "``"))
- ;; in this mode we exceptionally ignore the user, else it's no fun
- pair t)
- (let ((map (make-keymap))
- (i ? ))
- (use-local-map map)
- (setq map (car (cdr map)))
- (while (< i ?\^?)
- (aset map i 'pair-insert-maybe)
- (setq i (1+ i))))
- (run-hooks 'mirror-mode-hook))
+;;;(defun mirror-mode ()
+;;; "This major mode is an amusing little example of paired insertion.
+;;;All printable characters do a paired self insert, while the other commands
+;;;work normally."
+;;; (interactive)
+;;; (kill-all-local-variables)
+;;; (make-local-variable 'pair)
+;;; (make-local-variable 'pair-on-word)
+;;; (make-local-variable 'pair-filter)
+;;; (make-local-variable 'pair-alist)
+;;; (setq major-mode 'mirror-mode
+;;; mode-name "Mirror"
+;;; pair-on-word t
+;;; ;; in the middle column insert one or none if odd window-width
+;;; pair-filter (lambda ()
+;;; (if (>= (current-column)
+;;; (/ (window-width) 2))
+;;; ;; insert both on next line
+;;; (next-line 1)
+;;; ;; insert one or both?
+;;; (= (* 2 (1+ (current-column)))
+;;; (window-width))))
+;;; ;; mirror these the other way round as well
+;;; pair-alist '((?) _ ?()
+;;; (?] _ ?[)
+;;; (?} _ ?{)
+;;; (?> _ ?<)
+;;; (?/ _ ?\\)
+;;; (?\\ _ ?/)
+;;; (?` ?` _ "''")
+;;; (?' ?' _ "``"))
+;;; ;; in this mode we exceptionally ignore the user, else it's no fun
+;;; pair t)
+;;; (let ((map (make-keymap))
+;;; (i ? ))
+;;; (use-local-map map)
+;;; (setq map (car (cdr map)))
+;;; (while (< i ?\^?)
+;;; (aset map i 'pair-insert-maybe)
+;;; (setq i (1+ i))))
+;;; (run-hooks 'mirror-mode-hook))
;; skeleton.el ends here