88155
|
1 ;;; sieve-mode.el --- Sieve code editing commands for Emacs
|
|
2
|
|
3 ;; Copyright (C) 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
|
|
4
|
|
5 ;; Author: Simon Josefsson <simon@josefsson.org>
|
|
6
|
|
7 ;; This file is part of GNU Emacs.
|
|
8
|
|
9 ;; GNU Emacs is free software; you can redistribute it and/or modify
|
|
10 ;; it under the terms of the GNU General Public License as published by
|
|
11 ;; the Free Software Foundation; either version 2, or (at your option)
|
|
12 ;; any later version.
|
|
13
|
|
14 ;; GNU Emacs is distributed in the hope that it will be useful,
|
|
15 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
16 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
17 ;; GNU General Public License for more details.
|
|
18
|
|
19 ;; You should have received a copy of the GNU General Public License
|
|
20 ;; along with GNU Emacs; see the file COPYING. If not, write to the
|
|
21 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
22 ;; Boston, MA 02110-1301, USA.
|
|
23
|
|
24 ;;; Commentary:
|
|
25
|
|
26 ;; This file contain editing mode functions and font-lock support for
|
|
27 ;; editing Sieve scripts. It sets up C-mode with support for
|
|
28 ;; sieve-style #-comments and a lightly hacked syntax table. It was
|
|
29 ;; strongly influenced by awk-mode.el.
|
|
30 ;;
|
|
31 ;; Put something similar to the following in your .emacs to use this file:
|
|
32 ;;
|
|
33 ;; (load "~/lisp/sieve")
|
|
34 ;; (setq auto-mode-alist (cons '("\\.siv\\'" . sieve-mode) auto-mode-alist))
|
|
35 ;;
|
|
36 ;; References:
|
|
37 ;;
|
|
38 ;; RFC 3028,
|
|
39 ;; "Sieve: A Mail Filtering Language",
|
|
40 ;; by Tim Showalter.
|
|
41 ;;
|
|
42 ;; Release history:
|
|
43 ;;
|
|
44 ;; 2001-03-02 version 1.0 posted to gnu.emacs.sources
|
|
45 ;; version 1.1 change file extension into ".siv" (official one)
|
|
46 ;; added keymap and menubar to hook into sieve-manage
|
|
47 ;; 2001-10-31 version 1.2 committed to Oort Gnus
|
|
48
|
|
49 ;;; Code:
|
|
50
|
|
51 (autoload 'sieve-manage "sieve")
|
|
52 (autoload 'sieve-upload "sieve")
|
|
53 (autoload 'c-mode "cc-mode")
|
|
54 (require 'easymenu)
|
|
55 (eval-when-compile
|
|
56 (require 'font-lock))
|
|
57
|
|
58 (defgroup sieve nil
|
|
59 "Sieve."
|
|
60 :group 'languages)
|
|
61
|
|
62 (defcustom sieve-mode-hook nil
|
|
63 "Hook run in sieve mode buffers."
|
|
64 :group 'sieve
|
|
65 :type 'hook)
|
|
66
|
|
67 ;; Font-lock
|
|
68
|
|
69 (defvar sieve-control-commands-face 'sieve-control-commands
|
|
70 "Face name used for Sieve Control Commands.")
|
|
71
|
|
72 (defface sieve-control-commands
|
|
73 '((((type tty) (class color)) (:foreground "blue" :weight light))
|
|
74 (((class grayscale) (background light)) (:foreground "LightGray" :bold t))
|
|
75 (((class grayscale) (background dark)) (:foreground "DimGray" :bold t))
|
|
76 (((class color) (background light)) (:foreground "Orchid"))
|
|
77 (((class color) (background dark)) (:foreground "LightSteelBlue"))
|
|
78 (t (:bold t)))
|
|
79 "Face used for Sieve Control Commands."
|
|
80 :group 'sieve)
|
|
81 ;; backward-compatibility alias
|
|
82 (put 'sieve-control-commands-face 'face-alias 'sieve-control-commands)
|
|
83
|
|
84 (defvar sieve-action-commands-face 'sieve-action-commands
|
|
85 "Face name used for Sieve Action Commands.")
|
|
86
|
|
87 (defface sieve-action-commands
|
|
88 '((((type tty) (class color)) (:foreground "blue" :weight bold))
|
|
89 (((class color) (background light)) (:foreground "Blue"))
|
|
90 (((class color) (background dark)) (:foreground "LightSkyBlue"))
|
|
91 (t (:inverse-video t :bold t)))
|
|
92 "Face used for Sieve Action Commands."
|
|
93 :group 'sieve)
|
|
94 ;; backward-compatibility alias
|
|
95 (put 'sieve-action-commands-face 'face-alias 'sieve-action-commands)
|
|
96
|
|
97 (defvar sieve-test-commands-face 'sieve-test-commands
|
|
98 "Face name used for Sieve Test Commands.")
|
|
99
|
|
100 (defface sieve-test-commands
|
|
101 '((((type tty) (class color)) (:foreground "magenta"))
|
|
102 (((class grayscale) (background light))
|
|
103 (:foreground "LightGray" :bold t :underline t))
|
|
104 (((class grayscale) (background dark))
|
|
105 (:foreground "Gray50" :bold t :underline t))
|
|
106 (((class color) (background light)) (:foreground "CadetBlue"))
|
|
107 (((class color) (background dark)) (:foreground "Aquamarine"))
|
|
108 (t (:bold t :underline t)))
|
|
109 "Face used for Sieve Test Commands."
|
|
110 :group 'sieve)
|
|
111 ;; backward-compatibility alias
|
|
112 (put 'sieve-test-commands-face 'face-alias 'sieve-test-commands)
|
|
113
|
|
114 (defvar sieve-tagged-arguments-face 'sieve-tagged-arguments
|
|
115 "Face name used for Sieve Tagged Arguments.")
|
|
116
|
|
117 (defface sieve-tagged-arguments
|
|
118 '((((type tty) (class color)) (:foreground "cyan" :weight bold))
|
|
119 (((class grayscale) (background light)) (:foreground "LightGray" :bold t))
|
|
120 (((class grayscale) (background dark)) (:foreground "DimGray" :bold t))
|
|
121 (((class color) (background light)) (:foreground "Purple"))
|
|
122 (((class color) (background dark)) (:foreground "Cyan"))
|
|
123 (t (:bold t)))
|
|
124 "Face used for Sieve Tagged Arguments."
|
|
125 :group 'sieve)
|
|
126 ;; backward-compatibility alias
|
|
127 (put 'sieve-tagged-arguments-face 'face-alias 'sieve-tagged-arguments)
|
|
128
|
|
129
|
|
130 (defconst sieve-font-lock-keywords
|
|
131 (eval-when-compile
|
|
132 (list
|
|
133 ;; control commands
|
|
134 (cons (regexp-opt '("require" "if" "else" "elsif" "stop"))
|
|
135 'sieve-control-commands-face)
|
|
136 ;; action commands
|
|
137 (cons (regexp-opt '("fileinto" "redirect" "reject" "keep" "discard"))
|
|
138 'sieve-action-commands-face)
|
|
139 ;; test commands
|
|
140 (cons (regexp-opt '("address" "allof" "anyof" "exists" "false"
|
|
141 "true" "header" "not" "size" "envelope"))
|
|
142 'sieve-test-commands-face)
|
|
143 (cons "\\Sw+:\\sw+"
|
|
144 'sieve-tagged-arguments-face))))
|
|
145
|
|
146 ;; Syntax table
|
|
147
|
|
148 (defvar sieve-mode-syntax-table nil
|
|
149 "Syntax table in use in sieve-mode buffers.")
|
|
150
|
|
151 (if sieve-mode-syntax-table
|
|
152 ()
|
|
153 (setq sieve-mode-syntax-table (make-syntax-table))
|
|
154 (modify-syntax-entry ?\\ "\\" sieve-mode-syntax-table)
|
|
155 (modify-syntax-entry ?\n "> " sieve-mode-syntax-table)
|
|
156 (modify-syntax-entry ?\f "> " sieve-mode-syntax-table)
|
|
157 (modify-syntax-entry ?\# "< " sieve-mode-syntax-table)
|
|
158 (modify-syntax-entry ?/ "." sieve-mode-syntax-table)
|
|
159 (modify-syntax-entry ?* "." sieve-mode-syntax-table)
|
|
160 (modify-syntax-entry ?+ "." sieve-mode-syntax-table)
|
|
161 (modify-syntax-entry ?- "." sieve-mode-syntax-table)
|
|
162 (modify-syntax-entry ?= "." sieve-mode-syntax-table)
|
|
163 (modify-syntax-entry ?% "." sieve-mode-syntax-table)
|
|
164 (modify-syntax-entry ?< "." sieve-mode-syntax-table)
|
|
165 (modify-syntax-entry ?> "." sieve-mode-syntax-table)
|
|
166 (modify-syntax-entry ?& "." sieve-mode-syntax-table)
|
|
167 (modify-syntax-entry ?| "." sieve-mode-syntax-table)
|
|
168 (modify-syntax-entry ?_ "_" sieve-mode-syntax-table)
|
|
169 (modify-syntax-entry ?\' "\"" sieve-mode-syntax-table))
|
|
170
|
|
171 ;; Key map definition
|
|
172
|
|
173 (defvar sieve-mode-map
|
|
174 (let ((map (make-sparse-keymap)))
|
|
175 (define-key map "\C-c\C-l" 'sieve-upload)
|
|
176 (define-key map "\C-c\C-c" 'sieve-upload-and-bury)
|
|
177 (define-key map "\C-c\C-m" 'sieve-manage)
|
|
178 map)
|
|
179 "Key map used in sieve mode.")
|
|
180
|
|
181 ;; Menu definition
|
|
182
|
|
183 (defvar sieve-mode-menu nil
|
|
184 "Menubar used in sieve mode.")
|
|
185
|
|
186 ;; Code for Sieve editing mode.
|
|
187
|
|
188 ;;;###autoload
|
|
189 (define-derived-mode sieve-mode c-mode "Sieve"
|
|
190 "Major mode for editing Sieve code.
|
|
191 This is much like C mode except for the syntax of comments. Its keymap
|
|
192 inherits from C mode's and it has the same variables for customizing
|
|
193 indentation. It has its own abbrev table and its own syntax table.
|
|
194
|
|
195 Turning on Sieve mode runs `sieve-mode-hook'."
|
|
196 (set (make-local-variable 'paragraph-start) (concat "$\\|" page-delimiter))
|
|
197 (set (make-local-variable 'paragraph-separate) paragraph-start)
|
|
198 (set (make-local-variable 'comment-start) "#")
|
|
199 (set (make-local-variable 'comment-end) "")
|
|
200 ;;(set (make-local-variable 'comment-start-skip) "\\(^\\|\\s-\\);?#+ *")
|
|
201 (set (make-local-variable 'comment-start-skip) "#+ *")
|
|
202 (unless (featurep 'xemacs)
|
|
203 (set (make-local-variable 'font-lock-defaults)
|
|
204 '(sieve-font-lock-keywords nil nil ((?_ . "w")))))
|
|
205 (easy-menu-add-item nil nil sieve-mode-menu))
|
|
206
|
|
207 ;; Menu
|
|
208
|
|
209 (easy-menu-define sieve-mode-menu sieve-mode-map
|
|
210 "Sieve Menu."
|
|
211 '("Sieve"
|
|
212 ["Upload script" sieve-upload t]
|
|
213 ["Manage scripts on server" sieve-manage t]))
|
|
214
|
|
215 (provide 'sieve-mode)
|
|
216
|
|
217 ;;; arch-tag: 3b8ab76d-065d-4c52-b1e8-ab2ec21f2ace
|
|
218 ;; sieve-mode.el ends here
|