annotate lisp/emacs-lisp/generic.el @ 112429:6e50030da731

Some copyright.el updates. * lisp/emacs-lisp/copyright.el (copyright-find-copyright): New function, split out from copyright-update-year. (copyright-update): Don't mess with the GPL version if we don't own the copyright. Update license regexp, and remove no longer needed Esperanto stuff.
author Glenn Morris <rgm@gnu.org>
date Sat, 22 Jan 2011 14:09:09 -0800
parents ef719132ddfa
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
1 ;;; generic.el --- defining simple major modes with comment and font-lock
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
2 ;;
74466
1d4b1a32fd66 Update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 68648
diff changeset
3 ;; Copyright (C) 1997, 1999, 2001, 2002, 2003, 2004,
112218
376148b31b5e Add 2011 to FSF/AIST copyright years.
Glenn Morris <rgm@gnu.org>
parents: 106815
diff changeset
4 ;; 2005, 2006, 2007, 2008, 2009, 2010, 2011 Free Software Foundation, Inc.
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
5 ;;
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
6 ;; Author: Peter Breton <pbreton@cs.umb.edu>
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
7 ;; Created: Fri Sep 27 1996
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
8 ;; Keywords: generic, comment, font-lock
110015
280c8ae2476d Add "Package:" file headers to denote built-in packages.
Chong Yidong <cyd@stupidchicken.com>
parents: 106815
diff changeset
9 ;; Package: emacs
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
10
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
11 ;; This file is part of GNU Emacs.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
12
94655
90a2847062be Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 91327
diff changeset
13 ;; GNU Emacs is free software: you can redistribute it and/or modify
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
14 ;; it under the terms of the GNU General Public License as published by
94655
90a2847062be Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 91327
diff changeset
15 ;; the Free Software Foundation, either version 3 of the License, or
90a2847062be Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 91327
diff changeset
16 ;; (at your option) any later version.
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
17
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
18 ;; GNU Emacs is distributed in the hope that it will be useful,
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
19 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
20 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
21 ;; GNU General Public License for more details.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
22
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
23 ;; You should have received a copy of the GNU General Public License
94655
90a2847062be Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 91327
diff changeset
24 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
25
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
26 ;;; Commentary:
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
27
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
28 ;; INTRODUCTION:
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
29 ;;
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
30 ;; The macro `define-generic-mode' can be used to define small modes
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
31 ;; which provide basic comment and font-lock support. These modes are
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
32 ;; intended for the many configuration files and such which are too
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
33 ;; small for a "real" mode, but still have a regular syntax, comment
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
34 ;; characters and the like.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
35 ;;
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
36 ;; Each generic mode can define the following:
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
37 ;;
61931
f3e1b2ceffd2 Improve commentary section.
Lute Kamstra <lute@gnu.org>
parents: 61916
diff changeset
38 ;; * List of comment-characters. The elements of this list should be
f3e1b2ceffd2 Improve commentary section.
Lute Kamstra <lute@gnu.org>
parents: 61916
diff changeset
39 ;; either a character, a one or two character string, or a cons
f3e1b2ceffd2 Improve commentary section.
Lute Kamstra <lute@gnu.org>
parents: 61916
diff changeset
40 ;; cell. If the entry is a character or a string, it is added to
f3e1b2ceffd2 Improve commentary section.
Lute Kamstra <lute@gnu.org>
parents: 61916
diff changeset
41 ;; the mode's syntax table with "comment starter" syntax. If the
f3e1b2ceffd2 Improve commentary section.
Lute Kamstra <lute@gnu.org>
parents: 61916
diff changeset
42 ;; entry is a cons cell, the `car' and `cdr' of the pair are
f3e1b2ceffd2 Improve commentary section.
Lute Kamstra <lute@gnu.org>
parents: 61916
diff changeset
43 ;; considered the "comment starter" and "comment ender"
f3e1b2ceffd2 Improve commentary section.
Lute Kamstra <lute@gnu.org>
parents: 61916
diff changeset
44 ;; respectively. (The latter should be nil if you want comments to
f3e1b2ceffd2 Improve commentary section.
Lute Kamstra <lute@gnu.org>
parents: 61916
diff changeset
45 ;; end at the end of the line.) Emacs does not support comment
f3e1b2ceffd2 Improve commentary section.
Lute Kamstra <lute@gnu.org>
parents: 61916
diff changeset
46 ;; strings of more than two characters in length.
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
47 ;;
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
48 ;; * List of keywords to font-lock. Each keyword should be a string.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
49 ;; If you have additional keywords which should be highlighted in a
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
50 ;; face different from `font-lock-keyword-face', you can use the
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
51 ;; convenience function `generic-make-keywords-list' (which see),
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
52 ;; and add the result to the following list:
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
53 ;;
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
54 ;; * Additional expressions to font-lock. This should be a list of
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
55 ;; expressions, each of which should be of the same form as those in
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
56 ;; `font-lock-keywords'.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
57 ;;
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
58 ;; * List of regular expressions to be placed in auto-mode-alist.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
59 ;;
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
60 ;; * List of functions to call to do some additional setup
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
61 ;;
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
62 ;; This should pretty much cover basic functionality; if you need much
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
63 ;; more than this, or you find yourself writing extensive customizations,
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
64 ;; perhaps you should be writing a major mode instead!
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
65 ;;
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
66 ;; EXAMPLE:
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
67 ;;
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
68 ;; You can use `define-generic-mode' like this:
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
69 ;;
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
70 ;; (define-generic-mode 'foo-generic-mode
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
71 ;; (list ?%)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
72 ;; (list "keyword")
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
73 ;; nil
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
74 ;; (list "\\.FOO\\'")
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
75 ;; (list 'foo-setup-function))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
76 ;;
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
77 ;; to define a new generic-mode `foo-generic-mode', which has '%' as a
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
78 ;; comment character, and "keyword" as a keyword. When files which
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
79 ;; end in '.FOO' are loaded, Emacs will go into foo-generic-mode and
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
80 ;; call foo-setup-function. You can also use the function
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
81 ;; `foo-generic-mode' (which is interactive) to put a buffer into
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
82 ;; foo-generic-mode.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
83 ;;
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
84 ;; GOTCHAS:
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
85 ;;
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
86 ;; Be careful that your font-lock definitions are correct. Getting
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
87 ;; them wrong can cause Emacs to continually attempt to fontify! This
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
88 ;; problem is not specific to generic-mode.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
89
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
90 ;; Credit for suggestions, brainstorming, help with debugging:
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
91 ;; ACorreir@pervasive-sw.com (Alfred Correira)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
92 ;; Extensive cleanup by:
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
93 ;; Stefan Monnier (monnier+gnu/emacs@flint.cs.yale.edu)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
94
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
95 ;;; Code:
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
96
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
97 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
98 ;; Internal Variables
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
99 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
100
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
101 (defvar generic-font-lock-keywords nil
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
102 "Keywords for `font-lock-defaults' in a generic mode.")
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
103 (make-variable-buffer-local 'generic-font-lock-keywords)
64908
45df3993d950 (generic-font-lock-defaults): Declare with define-obsolete-variable-alias.
Lute Kamstra <lute@gnu.org>
parents: 64751
diff changeset
104 (define-obsolete-variable-alias 'generic-font-lock-defaults 'generic-font-lock-keywords "22.1")
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
105
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
106 ;;;###autoload
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
107 (defvar generic-mode-list nil
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
108 "A list of mode names for `generic-mode'.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
109 Do not add entries to this list directly; use `define-generic-mode'
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
110 instead (which see).")
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
111
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
112 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
113 ;; Functions
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
114 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
115
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
116 ;;;###autoload
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
117 (defmacro define-generic-mode (mode comment-list keyword-list
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
118 font-lock-list auto-mode-list
62260
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
119 function-list &optional docstring)
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
120 "Create a new generic mode MODE.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
121
62260
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
122 MODE is the name of the command for the generic mode; don't quote it.
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
123 The optional DOCSTRING is the documentation for the mode command. If
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
124 you do not supply it, `define-generic-mode' uses a default
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
125 documentation string instead.
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
126
62260
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
127 COMMENT-LIST is a list in which each element is either a character, a
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
128 string of one or two characters, or a cons cell. A character or a
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
129 string is set up in the mode's syntax table as a \"comment starter\".
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
130 If the entry is a cons cell, the `car' is set up as a \"comment
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
131 starter\" and the `cdr' as a \"comment ender\". (Use nil for the
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
132 latter if you want comments to end at the end of the line.) Note that
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
133 the syntax table has limitations about what comment starters and
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
134 enders are actually possible.
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
135
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
136 KEYWORD-LIST is a list of keywords to highlight with
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
137 `font-lock-keyword-face'. Each keyword should be a string.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
138
62260
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
139 FONT-LOCK-LIST is a list of additional expressions to highlight. Each
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
140 element of this list should have the same form as an element of
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
141 `font-lock-keywords'.
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
142
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
143 AUTO-MODE-LIST is a list of regular expressions to add to
62260
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
144 `auto-mode-alist'. These regular expressions are added when Emacs
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
145 runs the macro expansion.
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
146
62260
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
147 FUNCTION-LIST is a list of functions to call to do some additional
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
148 setup. The mode command calls these functions just before it runs the
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
149 mode hook `MODE-hook'.
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
150
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
151 See the file generic-x.el for some examples of `define-generic-mode'."
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
152 (declare (debug (sexp def-form def-form def-form form def-form
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
153 [&optional stringp] &rest [keywordp form]))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
154 (indent 1))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
155
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
156 ;; Backward compatibility.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
157 (when (eq (car-safe mode) 'quote)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
158 (setq mode (eval mode)))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
159
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
160 (let* ((name (symbol-name mode))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
161 (pretty-name (capitalize (replace-regexp-in-string
62260
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
162 "-mode\\'" "" name))))
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
163
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
164 `(progn
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
165 ;; Add a new entry.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
166 (add-to-list 'generic-mode-list ,name)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
167
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
168 ;; Add it to auto-mode-alist
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
169 (dolist (re ,auto-mode-list)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
170 (add-to-list 'auto-mode-alist (cons re ',mode)))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
171
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
172 (defun ,mode ()
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
173 ,(or docstring
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
174 (concat pretty-name " mode.\n"
62260
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
175 "This a generic mode defined with `define-generic-mode'.\n"
a0af6e05c03a (define-generic-mode): Don't generate a defcustom for the mode hook
Lute Kamstra <lute@gnu.org>
parents: 61931
diff changeset
176 "It runs `" name "-hook' as the last thing it does."))
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
177 (interactive)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
178 (generic-mode-internal ',mode ,comment-list ,keyword-list
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
179 ,font-lock-list ,function-list)))))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
180
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
181 ;;;###autoload
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
182 (defun generic-mode-internal (mode comment-list keyword-list
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
183 font-lock-list function-list)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
184 "Go into the generic mode MODE."
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
185 (let* ((name (symbol-name mode))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
186 (pretty-name (capitalize (replace-regexp-in-string
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
187 "-mode\\'" "" name)))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
188 (mode-hook (intern (concat name "-hook"))))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
189
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
190 (kill-all-local-variables)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
191
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
192 (setq major-mode mode
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
193 mode-name pretty-name)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
194
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
195 (generic-mode-set-comments comment-list)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
196
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
197 ;; Font-lock functionality.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
198 ;; Font-lock-defaults is always set even if there are no keywords
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
199 ;; or font-lock expressions, so comments can be highlighted.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
200 (setq generic-font-lock-keywords font-lock-list)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
201 (when keyword-list
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
202 (push (concat "\\_<" (regexp-opt keyword-list t) "\\_>")
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
203 generic-font-lock-keywords))
61904
114b2859d567 (generic-mode-internal): Simplify font-lock-defaults.
Lute Kamstra <lute@gnu.org>
parents: 61521
diff changeset
204 (setq font-lock-defaults '(generic-font-lock-keywords))
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
205
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
206 ;; Call a list of functions
84901
c22466a5f332 (generic-mode-internal): Use `mapc' rather than `mapcar'.
Juanma Barranquero <lekktu@gmail.com>
parents: 78217
diff changeset
207 (mapc 'funcall function-list)
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
208
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
209 (run-mode-hooks mode-hook)))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
210
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
211 ;;;###autoload
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
212 (defun generic-mode (mode)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
213 "Enter generic mode MODE.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
214
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
215 Generic modes provide basic comment and font-lock functionality
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
216 for \"generic\" files. (Files which are too small to warrant their
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
217 own mode, but have comment characters, keywords, and the like.)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
218
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
219 To define a generic-mode, use the function `define-generic-mode'.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
220 Some generic modes are defined in `generic-x.el'."
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
221 (interactive
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
222 (list (completing-read "Generic mode: " generic-mode-list nil t)))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
223 (funcall (intern mode)))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
224
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
225 ;;; Comment Functionality
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
226 (defun generic-mode-set-comments (comment-list)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
227 "Set up comment functionality for generic mode."
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
228 (let ((st (make-syntax-table))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
229 (chars nil)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
230 (comstyles))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
231 (make-local-variable 'comment-start)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
232 (make-local-variable 'comment-start-skip)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
233 (make-local-variable 'comment-end)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
234
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
235 ;; Go through all the comments
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
236 (dolist (start comment-list)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
237 (let (end (comstyle ""))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
238 ;; Normalize
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
239 (when (consp start)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
240 (setq end (cdr start))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
241 (setq start (car start)))
90143
146c086df160 Revision: miles@gnu.org--gnu-2005/emacs--unicode--0--patch-37
Miles Bader <miles@gnu.org>
parents: 61521
diff changeset
242 (when (characterp start) (setq start (char-to-string start)))
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
243 (cond
90143
146c086df160 Revision: miles@gnu.org--gnu-2005/emacs--unicode--0--patch-37
Miles Bader <miles@gnu.org>
parents: 61521
diff changeset
244 ((characterp end) (setq end (char-to-string end)))
61521
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
245 ((zerop (length end)) (setq end "\n")))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
246
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
247 ;; Setup the vars for `comment-region'
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
248 (if comment-start
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
249 ;; We have already setup a comment-style, so use style b
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
250 (progn
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
251 (setq comstyle "b")
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
252 (setq comment-start-skip
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
253 (concat comment-start-skip "\\|" (regexp-quote start) "+\\s-*")))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
254 ;; First comment-style
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
255 (setq comment-start start)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
256 (setq comment-end (if (string-equal end "\n") "" end))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
257 (setq comment-start-skip (concat (regexp-quote start) "+\\s-*")))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
258
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
259 ;; Reuse comstyles if necessary
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
260 (setq comstyle
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
261 (or (cdr (assoc start comstyles))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
262 (cdr (assoc end comstyles))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
263 comstyle))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
264 (push (cons start comstyle) comstyles)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
265 (push (cons end comstyle) comstyles)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
266
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
267 ;; Setup the syntax table
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
268 (if (= (length start) 1)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
269 (modify-syntax-entry (string-to-char start)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
270 (concat "< " comstyle) st)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
271 (let ((c0 (elt start 0)) (c1 (elt start 1)))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
272 ;; Store the relevant info but don't update yet
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
273 (push (cons c0 (concat (cdr (assoc c0 chars)) "1")) chars)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
274 (push (cons c1 (concat (cdr (assoc c1 chars))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
275 (concat "2" comstyle))) chars)))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
276 (if (= (length end) 1)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
277 (modify-syntax-entry (string-to-char end)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
278 (concat ">" comstyle) st)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
279 (let ((c0 (elt end 0)) (c1 (elt end 1)))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
280 ;; Store the relevant info but don't update yet
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
281 (push (cons c0 (concat (cdr (assoc c0 chars))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
282 (concat "3" comstyle))) chars)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
283 (push (cons c1 (concat (cdr (assoc c1 chars)) "4")) chars)))))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
284
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
285 ;; Process the chars that were part of a 2-char comment marker
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
286 (dolist (cs (nreverse chars))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
287 (modify-syntax-entry (car cs)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
288 (concat (char-to-string (char-syntax (car cs)))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
289 " " (cdr cs))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
290 st))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
291 (set-syntax-table st)))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
292
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
293 (defun generic-bracket-support ()
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
294 "Imenu support for [KEYWORD] constructs found in INF, INI and Samba files."
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
295 (setq imenu-generic-expression
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
296 '((nil "^\\[\\(.*\\)\\]" 1))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
297 imenu-case-fold-search t))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
298
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
299 ;;;###autoload
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
300 (defun generic-make-keywords-list (keyword-list face &optional prefix suffix)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
301 "Return a `font-lock-keywords' construct that highlights KEYWORD-LIST.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
302 KEYWORD-LIST is a list of keyword strings that should be
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
303 highlighted with face FACE. This function calculates a regular
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
304 expression that matches these keywords and concatenates it with
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
305 PREFIX and SUFFIX. Then it returns a construct based on this
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
306 regular expression that can be used as an element of
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
307 `font-lock-keywords'."
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
308 (unless (listp keyword-list)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
309 (error "Keywords argument must be a list of strings"))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
310 (list (concat prefix "\\_<"
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
311 ;; Use an optimized regexp.
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
312 (regexp-opt keyword-list t)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
313 "\\_>" suffix)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
314 1
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
315 face))
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
316
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
317 (provide 'generic)
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
318
2f8b7bd746aa Move here from parent dir.
Lute Kamstra <lute@gnu.org>
parents:
diff changeset
319 ;;; generic.el ends here