2001-07-16 12:23:00 +00:00
|
|
|
|
;;; expand.el --- make abbreviations more usable
|
1996-12-28 19:41:45 +00:00
|
|
|
|
|
2006-12-05 06:15:26 +00:00
|
|
|
|
;; Copyright (C) 1995, 1996, 2001, 2002, 2003, 2004,
|
2007-01-21 03:53:13 +00:00
|
|
|
|
;; 2005, 2006, 2007 Free Software Foundation, Inc.
|
1996-12-28 19:41:45 +00:00
|
|
|
|
|
|
|
|
|
;; Author: Frederic Lepied <Frederic.Lepied@sugix.frmug.org>
|
|
|
|
|
;; Maintainer: Frederic Lepied <Frederic.Lepied@sugix.frmug.org>
|
|
|
|
|
;; Keywords: abbrev
|
|
|
|
|
|
|
|
|
|
;; This file is part of GNU Emacs.
|
|
|
|
|
|
|
|
|
|
;; GNU Emacs is free software; you can redistribute it and/or modify
|
|
|
|
|
;; it under the terms of the GNU General Public License as published by
|
2007-07-25 04:50:21 +00:00
|
|
|
|
;; the Free Software Foundation; either version 3, or (at your option)
|
1996-12-28 19:41:45 +00:00
|
|
|
|
;; any later version.
|
|
|
|
|
|
|
|
|
|
;; GNU Emacs is distributed in the hope that it will be useful,
|
|
|
|
|
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
;; GNU General Public License for more details.
|
|
|
|
|
|
|
|
|
|
;; You should have received a copy of the GNU General Public License
|
|
|
|
|
;; along with GNU Emacs; see the file COPYING. If not, write to the
|
2005-07-04 23:32:44 +00:00
|
|
|
|
;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
|
|
|
;; Boston, MA 02110-1301, USA.
|
1996-12-28 19:41:45 +00:00
|
|
|
|
|
|
|
|
|
;;; Commentary:
|
|
|
|
|
;;
|
1996-12-28 20:06:56 +00:00
|
|
|
|
;; This package defines abbrevs which expand into structured constructs
|
|
|
|
|
;; for certain languages. The construct is indented for you,
|
1997-01-07 08:14:12 +00:00
|
|
|
|
;; and contains slots for you to fill in other text.
|
1996-12-28 20:06:56 +00:00
|
|
|
|
|
|
|
|
|
;; These abbrevs expand only at the end of a line and when not in a comment
|
|
|
|
|
;; or a string.
|
1996-12-28 19:41:45 +00:00
|
|
|
|
;;
|
|
|
|
|
;; Look at the Sample: section for emacs-lisp, perl and c expand lists.
|
|
|
|
|
;; For example for c-mode, you could declare your abbrev table with :
|
|
|
|
|
;;
|
|
|
|
|
;; (defconst c-expand-list
|
|
|
|
|
;; '(("if" "if () {\n \n} else {\n \n}" (5 10 21))
|
|
|
|
|
;; ("ifn" "if () {}" (5 8))
|
|
|
|
|
;; ("uns" "unsigned ")
|
|
|
|
|
;; ("for" "for(; ; ) {\n\n}" (5 7 9 13))
|
|
|
|
|
;; ("switch" "switch () {\n\n}" (9 13))
|
|
|
|
|
;; ("case" "case :\n\nbreak;\n" (6 8 16))
|
|
|
|
|
;; ("do" "do {\n\n} while ();" (6 16))
|
|
|
|
|
;; ("while" "while () {\n\n}" (8 12))
|
|
|
|
|
;; ("default" "default:\n\nbreak;" 10)
|
|
|
|
|
;; ("main" "int\nmain(int argc, char * argv[])\n{\n\n}\n" 37))
|
|
|
|
|
;; "Expansions for C mode")
|
2001-11-27 18:03:29 +00:00
|
|
|
|
;;
|
1997-01-07 08:14:12 +00:00
|
|
|
|
;; and enter Abbrev mode with the following hook :
|
1996-12-28 19:41:45 +00:00
|
|
|
|
;;
|
2007-03-24 16:39:43 +00:00
|
|
|
|
;; (add-hook 'c-mode-hook
|
|
|
|
|
;; (lambda ()
|
|
|
|
|
;; (expand-add-abbrevs c-mode-abbrev-table c-expand-list)
|
|
|
|
|
;; (abbrev-mode 1)))
|
1996-12-28 19:41:45 +00:00
|
|
|
|
;;
|
1997-01-07 08:14:12 +00:00
|
|
|
|
;; you can also init some post-process hooks :
|
1996-12-28 19:41:45 +00:00
|
|
|
|
;;
|
1997-01-07 08:14:12 +00:00
|
|
|
|
;; (add-hook 'expand-load-hook
|
2007-03-24 16:39:43 +00:00
|
|
|
|
;; (lambda ()
|
|
|
|
|
;; (add-hook 'expand-expand-hook 'indent-according-to-mode)
|
|
|
|
|
;; (add-hook 'expand-jump-hook 'indent-according-to-mode)))
|
1996-12-28 19:41:45 +00:00
|
|
|
|
;;
|
|
|
|
|
;; Remarks:
|
|
|
|
|
;;
|
|
|
|
|
;; Many thanks to Heddy Boubaker <boubaker@cenatls.cena.dgac.fr>,
|
|
|
|
|
;; Jerome Santini <santini@chambord.univ-orleans.fr>,
|
|
|
|
|
;; Jari Aalto <jaalto@tre.tele.nokia.fi>.
|
|
|
|
|
;;
|
1997-01-07 08:14:12 +00:00
|
|
|
|
;; Please send me a word to give me your feeling about this feature or
|
1996-12-28 19:41:45 +00:00
|
|
|
|
;; to explain me how you use it (your expansions table for example) using
|
1997-01-07 08:14:12 +00:00
|
|
|
|
;; the function expand-submit-report.
|
1999-01-29 14:12:49 +00:00
|
|
|
|
;;; Code:
|
1996-12-28 19:41:45 +00:00
|
|
|
|
|
|
|
|
|
;;; Constants:
|
|
|
|
|
|
1998-01-07 10:31:09 +00:00
|
|
|
|
(defgroup expand nil
|
|
|
|
|
"Make abbreviations more usable."
|
|
|
|
|
:group 'abbrev)
|
1996-12-28 19:41:45 +00:00
|
|
|
|
|
1998-01-07 10:31:09 +00:00
|
|
|
|
(defcustom expand-load-hook nil
|
|
|
|
|
"Hooks run when `expand.el' is loaded."
|
|
|
|
|
:type 'hook
|
|
|
|
|
:group 'expand)
|
1996-12-28 19:41:45 +00:00
|
|
|
|
|
1998-01-07 10:31:09 +00:00
|
|
|
|
(defcustom expand-expand-hook nil
|
|
|
|
|
"Hooks run when an abbrev made by `expand-add-abbrevs' is expanded."
|
|
|
|
|
:type 'hook
|
|
|
|
|
:group 'expand)
|
|
|
|
|
|
|
|
|
|
(defcustom expand-jump-hook nil
|
|
|
|
|
"Hooks run by `expand-jump-to-previous-slot' and `expand-jump-to-next-slot'."
|
|
|
|
|
:type 'hook
|
|
|
|
|
:group 'expand)
|
1996-12-28 19:41:45 +00:00
|
|
|
|
|
|
|
|
|
;;; Samples:
|
|
|
|
|
|
|
|
|
|
(define-skeleton expand-c-for-skeleton "For loop skeleton"
|
|
|
|
|
"Loop var: "
|
|
|
|
|
"for(" str _ @ "=0; " str @ "; " str @ ") {" \n
|
|
|
|
|
@ _ \n
|
2001-10-12 16:39:20 +00:00
|
|
|
|
"}" > \n)
|
1996-12-28 19:41:45 +00:00
|
|
|
|
|
|
|
|
|
(defconst expand-c-sample-expand-list
|
|
|
|
|
'(("if" "if () {\n \n} else {\n \n}" (5 10 21))
|
|
|
|
|
("ifn" "if () {}" (5 8))
|
|
|
|
|
("uns" "unsigned ")
|
|
|
|
|
("for" expand-c-for-skeleton)
|
|
|
|
|
("switch" "switch () {\n\n}" (9 13))
|
|
|
|
|
("case" "case :\n\nbreak;\n" (6 8 16))
|
|
|
|
|
("do" "do {\n\n} while ();" (6 16))
|
|
|
|
|
("while" "while () {\n\n}" (8 12))
|
|
|
|
|
("default" "default:\n\nbreak;" 10)
|
|
|
|
|
("main" "int\nmain(int argc, char * argv[])\n{\n\n}\n" 37))
|
|
|
|
|
"Expansions for C mode. See `expand-add-abbrevs'.")
|
|
|
|
|
|
|
|
|
|
;; lisp example from Jari Aalto <jaalto@tre.tele.nokia.fi>
|
|
|
|
|
(defconst expand-sample-lisp-mode-expand-list
|
|
|
|
|
(list
|
|
|
|
|
(list
|
|
|
|
|
"defu"
|
|
|
|
|
(concat
|
|
|
|
|
"(defun ()\n"
|
|
|
|
|
" \"\"\n"
|
|
|
|
|
" (interactive)\n"
|
|
|
|
|
" (let* (\n"
|
|
|
|
|
" )\n"
|
|
|
|
|
" \n"
|
|
|
|
|
" ))")
|
|
|
|
|
(list 8 11 16 32 43 59))
|
|
|
|
|
|
|
|
|
|
(list
|
|
|
|
|
"defs"
|
|
|
|
|
(concat
|
|
|
|
|
"(defsubst ()\n"
|
|
|
|
|
" \"\"\n"
|
|
|
|
|
" (interactive)\n"
|
|
|
|
|
" )")
|
|
|
|
|
(list 11 14 19 23 39))
|
|
|
|
|
|
|
|
|
|
(list
|
|
|
|
|
"defm"
|
|
|
|
|
(concat
|
|
|
|
|
"(defmacro ()\n"
|
|
|
|
|
" \"\"\n"
|
2001-11-27 18:03:29 +00:00
|
|
|
|
" `( \n"
|
1996-12-28 19:41:45 +00:00
|
|
|
|
" ))")
|
|
|
|
|
(list 11 13 18 25))
|
|
|
|
|
|
|
|
|
|
(list
|
|
|
|
|
"defa"
|
|
|
|
|
(concat
|
|
|
|
|
"(defadvice (around act)\n"
|
|
|
|
|
" \"\"\n"
|
|
|
|
|
" \n"
|
|
|
|
|
" )")
|
|
|
|
|
(list 12 22 32 36))
|
|
|
|
|
|
|
|
|
|
(list
|
|
|
|
|
"defc"
|
|
|
|
|
"(defconst nil\n \"\")\n"
|
|
|
|
|
(list 11 13 20))
|
|
|
|
|
|
|
|
|
|
(list
|
|
|
|
|
"defv"
|
|
|
|
|
"(defvar nil\n \"\")\n"
|
|
|
|
|
(list 9 11 18))
|
|
|
|
|
|
|
|
|
|
(list
|
|
|
|
|
"let"
|
|
|
|
|
"(let* (\n)\n "
|
|
|
|
|
(list 8 13))
|
|
|
|
|
|
|
|
|
|
(list
|
|
|
|
|
"sav"
|
|
|
|
|
"(save-excursion\n \n)"
|
|
|
|
|
(list 18))
|
|
|
|
|
|
|
|
|
|
(list
|
|
|
|
|
"aut"
|
|
|
|
|
"(autoload ' \"\" t t)\n"
|
|
|
|
|
(list 12 14))
|
|
|
|
|
|
|
|
|
|
)
|
|
|
|
|
"Expansions for Lisp mode. See `expand-add-abbrevs'.")
|
2001-11-27 18:03:29 +00:00
|
|
|
|
|
1996-12-28 19:41:45 +00:00
|
|
|
|
;; perl example from Jari Aalto <jaalto@tre.tele.nokia.fi>
|
|
|
|
|
(defconst expand-sample-perl-mode-expand-list
|
|
|
|
|
(list
|
|
|
|
|
(list
|
|
|
|
|
;; This is default perl4 subroutine template
|
|
|
|
|
;;
|
|
|
|
|
"sub"
|
|
|
|
|
(concat
|
|
|
|
|
"#" (make-string 70 ?-) "\n"
|
|
|
|
|
"sub {\n"
|
|
|
|
|
" # DESCRIPTION\n"
|
|
|
|
|
" # \n"
|
|
|
|
|
" # \n"
|
|
|
|
|
" # INPUT\n"
|
|
|
|
|
" # \n"
|
|
|
|
|
" # \n"
|
|
|
|
|
" # RETURN\n"
|
|
|
|
|
" # \n"
|
|
|
|
|
"\n"
|
|
|
|
|
" local( $f ) = \"$lib.\";\n" ;; Function name AFTER period
|
|
|
|
|
" local() = @_;\n" ;; func arguments here
|
|
|
|
|
" \n"
|
|
|
|
|
" \n}\n"
|
|
|
|
|
)
|
|
|
|
|
(list 77 88 120 146 159 176))
|
|
|
|
|
|
|
|
|
|
(list
|
|
|
|
|
"for" ; foreach
|
|
|
|
|
(concat
|
|
|
|
|
"for ( )\n"
|
|
|
|
|
"{\n\n\}"
|
|
|
|
|
)
|
|
|
|
|
(list 7 12))
|
|
|
|
|
|
|
|
|
|
(list
|
|
|
|
|
"whi" ; foreach
|
|
|
|
|
(concat
|
|
|
|
|
"while ( )\n"
|
|
|
|
|
"{\n\n\}"
|
|
|
|
|
)
|
|
|
|
|
(list 9 15))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
;; The normal "if" can be used like
|
|
|
|
|
;; print $F "xxxxxx" if defined @arr;
|
|
|
|
|
;;
|
|
|
|
|
(list
|
|
|
|
|
"iff"
|
|
|
|
|
(concat
|
|
|
|
|
"if ( )\n"
|
|
|
|
|
"{\n\n\}"
|
|
|
|
|
)
|
|
|
|
|
(list 6 12))
|
|
|
|
|
|
|
|
|
|
(list "loc" "local( $ );" (list 9))
|
|
|
|
|
(list "my" "my( $ );" (list 6))
|
|
|
|
|
(list "ope" "open(,\"\")\t|| die \"$f: Can't open [$]\";" (list 6 8 36))
|
|
|
|
|
(list "clo" "close ;" 7)
|
|
|
|
|
(list "def" "defined " (list 9))
|
|
|
|
|
(list "und" "undef ;" (list 7))
|
|
|
|
|
|
|
|
|
|
;; There is no ending colon, because they can be in statement
|
|
|
|
|
;; defined $REXP_NOT_NEW && (print "xxxxx" );
|
|
|
|
|
;;
|
|
|
|
|
(list "pr" "print " 7)
|
|
|
|
|
(list "pf" "printf " 8)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
(list "gre" "grep( //, );" (list 8 11))
|
|
|
|
|
(list "pus" "push( , );" (list 7 9))
|
|
|
|
|
(list "joi" "join( '', );" (list 7 11))
|
|
|
|
|
(list "rtu" "return ;" (list 8))
|
|
|
|
|
|
|
|
|
|
)
|
|
|
|
|
"Expansions for Perl mode. See `expand-add-abbrevs'.")
|
|
|
|
|
|
|
|
|
|
;;; Code:
|
|
|
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
|
(defun expand-add-abbrevs (table abbrevs)
|
1996-12-28 20:06:56 +00:00
|
|
|
|
"Add a list of abbrev to abbrev table TABLE.
|
|
|
|
|
ABBREVS is a list of abbrev definitions; each abbrev description entry
|
|
|
|
|
has the form (ABBREV EXPANSION ARG).
|
|
|
|
|
|
|
|
|
|
ABBREV is the abbreviation to replace.
|
|
|
|
|
|
|
|
|
|
EXPANSION is the replacement string or a function which will make the
|
|
|
|
|
expansion. For example you, could use the DMacros or skeleton packages
|
1996-12-28 19:41:45 +00:00
|
|
|
|
to generate such functions.
|
1996-12-28 20:06:56 +00:00
|
|
|
|
|
|
|
|
|
ARG is an optional argument which can be a number or a list of
|
|
|
|
|
numbers. If ARG is a number, point is placed ARG chars from the
|
|
|
|
|
beginning of the expanded text.
|
|
|
|
|
|
|
|
|
|
If ARG is a list of numbers, point is placed according to the first
|
|
|
|
|
member of the list, but you can visit the other specified positions
|
1997-01-07 08:14:12 +00:00
|
|
|
|
cyclicaly with the functions `expand-jump-to-previous-slot' and
|
|
|
|
|
`expand-jump-to-next-slot'.
|
1996-12-28 20:06:56 +00:00
|
|
|
|
|
|
|
|
|
If ARG is omitted, point is placed at the end of the expanded text."
|
|
|
|
|
|
1996-12-28 19:41:45 +00:00
|
|
|
|
(if (null abbrevs)
|
|
|
|
|
table
|
|
|
|
|
(expand-add-abbrev table (nth 0 (car abbrevs)) (nth 1 (car abbrevs))
|
|
|
|
|
(nth 2 (car abbrevs)))
|
|
|
|
|
(expand-add-abbrevs table (cdr abbrevs))))
|
|
|
|
|
|
1997-01-07 08:14:12 +00:00
|
|
|
|
(defvar expand-list nil "Temporary variable used by the Expand package.")
|
1996-12-28 19:41:45 +00:00
|
|
|
|
|
|
|
|
|
(defvar expand-pos nil
|
2006-11-03 15:06:55 +00:00
|
|
|
|
"If non-nil, stores a vector containing markers to positions defined by the last expansion.
|
1996-12-28 19:41:45 +00:00
|
|
|
|
This variable is local to a buffer.")
|
|
|
|
|
(make-variable-buffer-local 'expand-pos)
|
|
|
|
|
|
|
|
|
|
(defvar expand-index 0
|
1996-12-28 20:06:56 +00:00
|
|
|
|
"Index of the last marker used in `expand-pos'.
|
1996-12-28 19:41:45 +00:00
|
|
|
|
This variable is local to a buffer.")
|
|
|
|
|
(make-variable-buffer-local 'expand-index)
|
|
|
|
|
|
|
|
|
|
(defvar expand-point nil
|
|
|
|
|
"End of the expanded region.
|
|
|
|
|
This variable is local to a buffer.")
|
|
|
|
|
(make-variable-buffer-local 'expand-point)
|
|
|
|
|
|
|
|
|
|
(defun expand-add-abbrev (table abbrev expansion arg)
|
|
|
|
|
"Add one abbreviation and provide the hook to move to the specified positions."
|
|
|
|
|
(let* ((string-exp (if (and (symbolp expansion) (fboundp expansion))
|
|
|
|
|
nil
|
|
|
|
|
expansion))
|
|
|
|
|
(position (if (and arg string-exp)
|
|
|
|
|
(if (listp arg)
|
|
|
|
|
(- (length expansion) (1- (car arg)))
|
|
|
|
|
(- (length expansion) (1- arg)))
|
|
|
|
|
0)))
|
|
|
|
|
(define-abbrev
|
|
|
|
|
table
|
|
|
|
|
abbrev
|
|
|
|
|
(vector string-exp
|
|
|
|
|
position
|
|
|
|
|
(if (and (listp arg)
|
|
|
|
|
(not (null arg)))
|
|
|
|
|
(cons (length string-exp) arg)
|
|
|
|
|
nil)
|
|
|
|
|
(if (and (symbolp expansion) (fboundp expansion))
|
|
|
|
|
expansion
|
|
|
|
|
nil)
|
|
|
|
|
)
|
|
|
|
|
'expand-abbrev-hook)))
|
|
|
|
|
|
1996-12-28 20:06:56 +00:00
|
|
|
|
(put 'expand-abbrev-hook 'no-self-insert t)
|
2007-03-24 16:39:43 +00:00
|
|
|
|
;;;###autoload
|
1996-12-28 20:06:56 +00:00
|
|
|
|
(defun expand-abbrev-hook ()
|
|
|
|
|
"Abbrev hook used to do the expansion job of expand abbrevs.
|
1999-12-30 12:25:22 +00:00
|
|
|
|
See `expand-add-abbrevs'. Value is non-nil if expansion was done."
|
1996-12-28 19:41:45 +00:00
|
|
|
|
;; Expand only at the end of a line if we are near a word that has
|
|
|
|
|
;; an abbrev built from expand-add-abbrev.
|
|
|
|
|
(if (and (eolp)
|
|
|
|
|
(not (expand-in-literal)))
|
|
|
|
|
(let ((p (point)))
|
|
|
|
|
(setq expand-point nil)
|
|
|
|
|
;; don't expand if the preceding char isn't a word constituent
|
|
|
|
|
(if (and (eq (char-syntax (preceding-char))
|
|
|
|
|
?w)
|
|
|
|
|
(expand-do-expansion))
|
|
|
|
|
(progn
|
|
|
|
|
;; expand-point tells us if we have inserted the text
|
|
|
|
|
;; ourself or if it is the hook which has done the job.
|
|
|
|
|
(if expand-point
|
|
|
|
|
(progn
|
|
|
|
|
(if (vectorp expand-list)
|
|
|
|
|
(expand-build-marks expand-point))
|
|
|
|
|
(indent-region p expand-point nil))
|
|
|
|
|
;; an outside function can set expand-list to a list of
|
|
|
|
|
;; markers in reverse order.
|
|
|
|
|
(if (listp expand-list)
|
|
|
|
|
(setq expand-index 0
|
|
|
|
|
expand-pos (expand-list-to-markers expand-list)
|
|
|
|
|
expand-list nil)))
|
|
|
|
|
(run-hooks 'expand-expand-hook)
|
1999-12-30 12:25:22 +00:00
|
|
|
|
t)
|
|
|
|
|
nil))
|
|
|
|
|
nil))
|
1996-12-28 19:41:45 +00:00
|
|
|
|
|
1996-12-28 20:06:56 +00:00
|
|
|
|
(defun expand-do-expansion ()
|
1996-12-28 19:41:45 +00:00
|
|
|
|
(delete-backward-char (length last-abbrev-text))
|
|
|
|
|
(let* ((vect (symbol-value last-abbrev))
|
|
|
|
|
(text (aref vect 0))
|
|
|
|
|
(position (aref vect 1))
|
|
|
|
|
(jump-args (aref vect 2))
|
|
|
|
|
(hook (aref vect 3)))
|
|
|
|
|
(cond (text
|
|
|
|
|
(insert text)
|
|
|
|
|
(setq expand-point (point))))
|
|
|
|
|
(if jump-args
|
|
|
|
|
(funcall 'expand-build-list (car jump-args) (cdr jump-args)))
|
|
|
|
|
(if position
|
|
|
|
|
(backward-char position))
|
|
|
|
|
(if hook
|
|
|
|
|
(funcall hook))
|
|
|
|
|
t)
|
|
|
|
|
)
|
|
|
|
|
|
1996-12-28 20:06:56 +00:00
|
|
|
|
(defun expand-abbrev-from-expand (word)
|
1996-12-28 19:41:45 +00:00
|
|
|
|
"Test if an abbrev has a hook."
|
|
|
|
|
(or
|
|
|
|
|
(and (intern-soft word local-abbrev-table)
|
|
|
|
|
(symbol-function (intern-soft word local-abbrev-table)))
|
|
|
|
|
(and (intern-soft word global-abbrev-table)
|
|
|
|
|
(symbol-function (intern-soft word global-abbrev-table)))))
|
|
|
|
|
|
|
|
|
|
(defun expand-previous-word ()
|
|
|
|
|
"Return the previous word."
|
|
|
|
|
(save-excursion
|
|
|
|
|
(let ((p (point)))
|
|
|
|
|
(backward-word 1)
|
|
|
|
|
(buffer-substring p (point)))))
|
|
|
|
|
|
1997-01-07 08:14:12 +00:00
|
|
|
|
;;;###autoload
|
|
|
|
|
(defun expand-jump-to-previous-slot ()
|
|
|
|
|
"Move the cursor to the previous slot in the last abbrev expansion.
|
|
|
|
|
This is used only in conjunction with `expand-add-abbrevs'."
|
1996-12-28 19:41:45 +00:00
|
|
|
|
(interactive)
|
|
|
|
|
(if expand-pos
|
|
|
|
|
(progn
|
|
|
|
|
(setq expand-index (1- expand-index))
|
|
|
|
|
(if (< expand-index 0)
|
|
|
|
|
(setq expand-index (1- (length expand-pos))))
|
|
|
|
|
(goto-char (aref expand-pos expand-index))
|
|
|
|
|
(run-hooks 'expand-jump-hook))))
|
|
|
|
|
|
1997-01-07 08:14:12 +00:00
|
|
|
|
;;;###autoload
|
|
|
|
|
(defun expand-jump-to-next-slot ()
|
|
|
|
|
"Move the cursor to the next slot in the last abbrev expansion.
|
|
|
|
|
This is used only in conjunction with `expand-add-abbrevs'."
|
1996-12-28 19:41:45 +00:00
|
|
|
|
(interactive)
|
|
|
|
|
(if expand-pos
|
|
|
|
|
(progn
|
|
|
|
|
(setq expand-index (1+ expand-index))
|
|
|
|
|
(if (>= expand-index (length expand-pos))
|
|
|
|
|
(setq expand-index 0))
|
|
|
|
|
(goto-char (aref expand-pos expand-index))
|
|
|
|
|
(run-hooks 'expand-jump-hook))))
|
|
|
|
|
|
1997-01-07 08:14:12 +00:00
|
|
|
|
;;;###autoload (define-key ctl-x-map "ap" 'expand-jump-to-previous-slot)
|
|
|
|
|
;;;###autoload (define-key ctl-x-map "an" 'expand-jump-to-next-slot)
|
|
|
|
|
|
1996-12-28 19:41:45 +00:00
|
|
|
|
(defun expand-build-list (len l)
|
|
|
|
|
"Build a vector of offset positions from the list of positions."
|
|
|
|
|
(expand-clear-markers)
|
|
|
|
|
(setq expand-list (vconcat l))
|
|
|
|
|
(let ((i 0)
|
|
|
|
|
(lenlist (length expand-list)))
|
|
|
|
|
(while (< i lenlist)
|
|
|
|
|
(aset expand-list i (- len (1- (aref expand-list i))))
|
|
|
|
|
(setq i (1+ i))))
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
(defun expand-build-marks (p)
|
|
|
|
|
"Transform the offsets vector into a marker vector."
|
|
|
|
|
(if expand-list
|
|
|
|
|
(progn
|
|
|
|
|
(setq expand-index 0)
|
|
|
|
|
(setq expand-pos (make-vector (length expand-list) nil))
|
|
|
|
|
(let ((i (1- (length expand-list))))
|
|
|
|
|
(while (>= i 0)
|
|
|
|
|
(aset expand-pos i (copy-marker (- p (aref expand-list i))))
|
|
|
|
|
(setq i (1- i))))
|
|
|
|
|
(setq expand-list nil))))
|
|
|
|
|
|
|
|
|
|
(defun expand-clear-markers ()
|
|
|
|
|
"Make the markers point nowhere."
|
|
|
|
|
(if expand-pos
|
|
|
|
|
(progn
|
|
|
|
|
(let ((i (1- (length expand-pos))))
|
|
|
|
|
(while (>= i 0)
|
|
|
|
|
(set-marker (aref expand-pos i) nil)
|
|
|
|
|
(setq i (1- i))))
|
|
|
|
|
(setq expand-pos nil))))
|
|
|
|
|
|
|
|
|
|
(defun expand-in-literal ()
|
|
|
|
|
"Test if we are in a comment or in a string."
|
|
|
|
|
(save-excursion
|
|
|
|
|
(let* ((lim (or (save-excursion
|
|
|
|
|
(beginning-of-defun)
|
|
|
|
|
(point))
|
|
|
|
|
(point-min)))
|
|
|
|
|
(here (point))
|
|
|
|
|
(state (parse-partial-sexp lim (point))))
|
|
|
|
|
(cond
|
|
|
|
|
((nth 3 state) 'string)
|
|
|
|
|
((nth 4 state) 'comment)
|
|
|
|
|
(t nil)))))
|
|
|
|
|
|
|
|
|
|
;; support functions to add marks to jump from outside function
|
|
|
|
|
|
|
|
|
|
(defun expand-list-to-markers (l)
|
|
|
|
|
"Transform a list of markers in reverse order into a vector in the correct order."
|
|
|
|
|
(let* ((len (1- (length l)))
|
|
|
|
|
(loop len)
|
|
|
|
|
(v (make-vector (+ len 1) nil)))
|
|
|
|
|
(while (>= loop 0)
|
|
|
|
|
(aset v loop (if (markerp (car l)) (car l) (copy-marker (car l))))
|
|
|
|
|
(setq l (cdr l)
|
|
|
|
|
loop (1- loop)))
|
|
|
|
|
v))
|
|
|
|
|
|
|
|
|
|
;; integration with skeleton.el
|
1996-12-28 20:06:56 +00:00
|
|
|
|
;; Used in `skeleton-end-hook' to fetch the positions for @ skeleton tags.
|
|
|
|
|
;; See `skeleton-insert'.
|
1996-12-28 19:41:45 +00:00
|
|
|
|
(defun expand-skeleton-end-hook ()
|
1996-12-28 20:06:56 +00:00
|
|
|
|
(if skeleton-positions
|
|
|
|
|
(setq expand-list skeleton-positions)))
|
2001-11-27 18:03:29 +00:00
|
|
|
|
|
1996-12-28 19:41:45 +00:00
|
|
|
|
(add-hook 'skeleton-end-hook (function expand-skeleton-end-hook))
|
|
|
|
|
|
|
|
|
|
(provide 'expand)
|
|
|
|
|
|
|
|
|
|
;; run load hooks
|
1997-01-07 08:14:12 +00:00
|
|
|
|
(run-hooks 'expand-load-hook)
|
1996-12-28 19:41:45 +00:00
|
|
|
|
|
2003-09-01 15:45:59 +00:00
|
|
|
|
;;; arch-tag: fee53e9e-30e3-4ef3-b191-9785e1f8e885
|
1996-12-28 19:41:45 +00:00
|
|
|
|
;;; expand.el ends here
|