Mercurial > emacs
annotate lisp/autoinsert.el @ 1868:f84d4b4b53da
* s/usg5-4.h: #include "usg5-3.h", not "s-usg5-3.h".
author | Jim Blandy <jimb@redhat.com> |
---|---|
date | Sun, 14 Feb 1993 14:36:14 +0000 |
parents | 213978acbc1e |
children | 10e417efb12a |
rev | line source |
---|---|
662
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
180
diff
changeset
|
1 ;;; autoinsert.el --- automatic mode-dependent insertion of text into new files |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
180
diff
changeset
|
2 |
845 | 3 ;; Copyright (C) 1985, 1986, 1987 Free Software Foundation, Inc. |
4 | |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
662
diff
changeset
|
5 ;; Author: Charlie Martin <crm@cs.duke.edu> |
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
662
diff
changeset
|
6 ;; Created: 01 Jul 1988 |
180 | 7 |
8 ;; This file is part of GNU Emacs. | |
9 | |
10 ;; GNU Emacs is free software; you can redistribute it and/or modify | |
11 ;; it under the terms of the GNU General Public License as published by | |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
662
diff
changeset
|
12 ;; the Free Software Foundation; either version 2, or (at your option) |
180 | 13 ;; any later version. |
14 | |
15 ;; GNU Emacs is distributed in the hope that it will be useful, | |
16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
18 ;; GNU General Public License for more details. | |
19 | |
20 ;; You should have received a copy of the GNU General Public License | |
21 ;; along with GNU Emacs; see the file COPYING. If not, write to | |
22 ;; the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. | |
23 | |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
662
diff
changeset
|
24 ;;; Commentary: |
180 | 25 |
26 ;;; Abstract: | |
27 ;;; | |
28 ;;; The following defines an association list for files to be | |
29 ;;; automatically inserted when a new file is created, and a function | |
30 ;;; which automatically inserts these files; the idea is to insert | |
31 ;;; default files much as the mode is automatically set using | |
32 ;;; auto-mode-alist. | |
33 ;;; | |
34 ;;; The auto-insert-alist consists of dotted pairs of | |
35 ;;; ( REGEXP . FILENAME ) where REGEXP is a regular expression, and | |
36 ;;; FILENAME is the file name of a file which is to be inserted into | |
37 ;;; all new files matching the regular expression with which it is | |
38 ;;; paired. | |
39 ;;; | |
40 ;;; To use: | |
41 ;;; load autoinsert.el | |
42 ;;; setq auto-insert-directory to an appropriate value, which | |
43 ;;; must end in "/" | |
44 ;;; | |
45 ;;; Author: Charlie Martin | |
46 ;;; Department of Computer Science and | |
47 ;;; National Biomedical Simulation Resource | |
48 ;;; Box 3709 | |
49 ;;; Duke University Medical Center | |
50 ;;; Durham, NC 27710 | |
51 ;;; (crm@cs.duke.edu,mcnc!duke!crm) | |
52 ;;; | |
53 ;;; Date: Fri Jul 1 16:15:31 EDT 1988 | |
54 | |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
662
diff
changeset
|
55 ;;; Code: |
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
662
diff
changeset
|
56 |
180 | 57 (defvar auto-insert-alist '(("\\.tex$" . "tex-insert.tex") |
58 ("\\.c$" . "c-insert.c") | |
59 ("\\.h$" . "h-insert.c") | |
60 ("[Mm]akefile" . "makefile.inc") | |
61 ("\\.bib$" . "tex-insert.tex")) | |
62 "A list specifying text to insert by default into a new file. | |
63 Elements look like (REGEXP . FILENAME); if the new file's name | |
64 matches REGEXP, then the file FILENAME is inserted into the buffer. | |
65 Only the first matching element is effective.") | |
66 | |
67 ;;; Establish a default value for auto-insert-directory | |
68 (defvar auto-insert-directory "~/insert/" | |
69 "*Directory from which auto-inserted files are taken.") | |
70 | |
71 (defun insert-auto-insert-files () | |
72 "Insert default contents into a new file. | |
73 Matches the visited file name against the elements of `auto-insert-alist'." | |
74 (let ((alist auto-insert-alist) | |
75 ;; remove backup suffixes from file name | |
76 (name (file-name-sans-versions buffer-file-name)) | |
77 (insert-file nil)) | |
78 | |
79 ;; find first matching alist entry | |
80 (while (and (not insert-file) alist) | |
81 (if (string-match (car (car alist)) name) | |
82 (setq insert-file (cdr (car alist))) | |
83 (setq alist (cdr alist)))) | |
84 | |
85 ;; Now, if we found an appropriate insert file, insert it | |
86 (if insert-file | |
87 (let ((file (concat auto-insert-directory insert-file))) | |
88 (if (file-readable-p file) | |
89 (progn | |
90 (insert-file-contents file) | |
91 (set-buffer-modified-p nil)) | |
92 (message "Auto-insert: file %s not found" file) | |
93 (sleep-for 1)))))) | |
94 | |
95 ;; Make this feature take effect when a nonexistent file is visited. | |
96 (setq find-file-not-found-hooks | |
97 (cons 'insert-auto-insert-files | |
98 find-file-not-found-hooks)) | |
662
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
180
diff
changeset
|
99 |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
180
diff
changeset
|
100 ;;; autoinsert.el ends here |