Mercurial > emacs
changeset 51244:18df58e3c486
(skeleton-internal-1): Don't loop if interactor of subskeleton is nil.
(skeleton-pair-default-alist): New var.
(skeleton-pair-insert-maybe): Use it.
author | Stefan Monnier <monnier@iro.umontreal.ca> |
---|---|
date | Mon, 26 May 2003 01:02:31 +0000 |
parents | c3aefed87855 |
children | f6920b201e1c |
files | lisp/skeleton.el |
diffstat | 1 files changed, 29 insertions(+), 25 deletions(-) [+] |
line wrap: on
line diff
--- a/lisp/skeleton.el Sun May 25 21:08:21 2003 +0000 +++ b/lisp/skeleton.el Mon May 26 01:02:31 2003 +0000 @@ -399,10 +399,13 @@ (push (point) skeleton-positions)) ((eq 'quote (car-safe element)) (eval (nth 1 element))) - ((or (stringp (car-safe element)) - (consp (car-safe element))) + ((and (consp element) + (or (stringp (car element)) (listp (car element)))) + ;; Don't forget: `symbolp' is also true for nil. (if (symbolp (car-safe (car element))) - (while (skeleton-internal-list element nil t)) + (while (and (skeleton-internal-list element nil t) + ;; If the interactor is nil, don't infinite loop. + (car element))) (setq literal (car element)) (while literal (skeleton-internal-list element (car literal)) @@ -462,6 +465,12 @@ Elements might be (?` ?` _ \"''\"), (?\\( ? _ \" )\") or (?{ \\n > _ \\n ?} >).") +(defvar skeleton-pair-default-alist '((?( _ ?)) (?\)) + (?[ _ ?]) (?\]) + (?{ _ ?}) (?\}) + (?< _ ?>) (?\>) + (?« _ ?») (?\») + (?` _ ?'))) ;;;###autoload (defun skeleton-pair-insert-maybe (arg) @@ -478,28 +487,23 @@ the defaults are used. These are (), [], {}, <> and `' for the symmetrical ones, and the same character twice for the others." (interactive "*P") - (let ((mark (and skeleton-autowrap - (or (eq last-command 'mouse-drag-region) - (and transient-mark-mode mark-active)))) - (skeleton-end-hook)) - (if (or arg - (not skeleton-pair) - (memq (char-syntax (preceding-char)) '(?\\ ?/)) - (and (not mark) - (or overwrite-mode - (if (not skeleton-pair-on-word) (looking-at "\\w")) - (funcall skeleton-pair-filter)))) - (self-insert-command (prefix-numeric-value arg)) - (setq last-command-char (logand last-command-char 255)) - (skeleton-insert - (cons nil (or (assq last-command-char skeleton-pair-alist) - (assq last-command-char '((?( _ ?)) - (?[ _ ?]) - (?{ _ ?}) - (?< _ ?>) - (?` _ ?'))) - `(,last-command-char _ ,last-command-char))) - (if mark -1))))) + (if (or arg (not skeleton-pair)) + (self-insert-command (prefix-numeric-value arg)) + (let* ((mark (and skeleton-autowrap + (or (eq last-command 'mouse-drag-region) + (and transient-mark-mode mark-active)))) + (skeleton-end-hook) + (char last-command-char) + (skeleton (or (assq char skeleton-pair-alist) + (assq char skeleton-pair-default-alist) + `(,char _ ,char)))) + (if (or (memq (char-syntax (preceding-char)) '(?\\ ?/)) + (and (not mark) + (or overwrite-mode + (if (not skeleton-pair-on-word) (looking-at "\\w")) + (funcall skeleton-pair-filter)))) + (self-insert-command (prefix-numeric-value arg)) + (skeleton-insert (cons nil skeleton) (if mark -1)))))) ;; A more serious example can be found in sh-script.el