annotate lisp/progmodes/cpp.el @ 66119:bc2d2dc9f534

(compilation-goto-locus): Display the compilation buffer first and the source buffer second, in case they're in overlapping frames. Don't raise the compilation frame if it was the selected window upon entry. Pass the `other-window' arg to pop-to-buffer.
author Stefan Monnier <monnier@iro.umontreal.ca>
date Sun, 16 Oct 2005 14:12:50 +0000
parents 629afbe74e61
children a11fdee52c05 edf295560b5a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
38436
b174db545cfd Some fixes to follow coding conventions.
Pavel Janík <Pavel@Janik.cz>
parents: 38078
diff changeset
1 ;;; cpp.el --- highlight or hide text according to cpp conditionals
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2
64699
629afbe74e61 Update copyright for release of 22.1 for progmodes directory.
Nick Roberts <nickrob@snap.net.nz>
parents: 64085
diff changeset
3 ;; Copyright (C) 1994, 1995, 2001, 2002, 2003, 2004, 2005
629afbe74e61 Update copyright for release of 22.1 for progmodes directory.
Nick Roberts <nickrob@snap.net.nz>
parents: 64085
diff changeset
4 ;; Free Software Foundation
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
5
17981
4d91d1db7ac0 Update address.
Per Abrahamsen <abraham@dina.kvl.dk>
parents: 16681
diff changeset
6 ;; Author: Per Abrahamsen <abraham@dina.kvl.dk>
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
7 ;; Keywords: c, faces, tools
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
8
8736
fe48762e68de *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 8735
diff changeset
9 ;; This file is part of GNU Emacs.
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
10
8736
fe48762e68de *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 8735
diff changeset
11 ;; GNU Emacs is free software; you can redistribute it and/or modify
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
12 ;; it under the terms of the GNU General Public License as published by
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
13 ;; the Free Software Foundation; either version 2, or (at your option)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
14 ;; any later version.
8736
fe48762e68de *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 8735
diff changeset
15
fe48762e68de *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 8735
diff changeset
16 ;; GNU Emacs is distributed in the hope that it will be useful,
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
17 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
19 ;; GNU General Public License for more details.
8736
fe48762e68de *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 8735
diff changeset
20
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
21 ;; You should have received a copy of the GNU General Public License
14169
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13974
diff changeset
22 ;; along with GNU Emacs; see the file COPYING. If not, write to the
64085
18a818a2ee7c Update FSF's address.
Lute Kamstra <lute@gnu.org>
parents: 63275
diff changeset
23 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
18a818a2ee7c Update FSF's address.
Lute Kamstra <lute@gnu.org>
parents: 63275
diff changeset
24 ;; Boston, MA 02110-1301, USA.
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
25
8736
fe48762e68de *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 8735
diff changeset
26 ;;; Commentary:
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
27
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
28 ;; Parse a text for C preprocessor conditionals, and highlight or hide
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
29 ;; the text inside the conditionals as you wish.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
30
8740
714588372e06 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 8736
diff changeset
31 ;; This package is inspired by Jim Coplien's delta editor for SCCS.
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
32
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
33 ;;; Todo:
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
34
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
35 ;; Should parse "#if" and "#elif" expressions and merge the faces
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 45431
diff changeset
36 ;; somehow.
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
37
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
38 ;; Somehow it is sometimes possible to make changes near a read only
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
39 ;; area which you can't undo. Their are other strange effects in that
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
40 ;; area.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
41
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
42 ;; The Edit buffer should -- optionally -- appear in its own frame.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
43
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
44 ;; Conditionals seem to be rear-sticky. They shouldn't be.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
45
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
46 ;; Restore window configurations when exiting CPP Edit buffer.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
47
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
48 ;;; Code:
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
49
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
50 ;;; Customization:
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
51 (defgroup cpp nil
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
52 "Highlight or hide text according to cpp conditionals."
28467
6ab0eec080f8 Change customization group to `c' from `C'.
Dave Love <fx@gnu.org>
parents: 23271
diff changeset
53 :group 'c
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
54 :prefix "cpp-")
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
55
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
56 (defcustom cpp-config-file (convert-standard-filename ".cpp.el")
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
57 "*File name to save cpp configuration."
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
58 :type 'file
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
59 :group 'cpp)
13911
3e9e8b468bc1 (cpp-config-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11492
diff changeset
60
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
61 (defcustom cpp-known-face 'invisible
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
62 "*Face used for known cpp symbols."
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
63 :type 'face
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
64 :group 'cpp)
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
65
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
66 (defcustom cpp-unknown-face 'highlight
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
67 "*Face used for unknown cpp symbols."
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
68 :type 'face
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
69 :group 'cpp)
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
70
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 45431
diff changeset
71 (defcustom cpp-face-type 'light
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
72 "*Indicate what background face type you prefer.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
73 Can be either light or dark for color screens, mono for monochrome
30541
d5e4d3d5012c (toplevel): Support faces on tty's.
Eli Zaretskii <eliz@gnu.org>
parents: 28467
diff changeset
74 screens, and none if you don't use a window system and don't have
d5e4d3d5012c (toplevel): Support faces on tty's.
Eli Zaretskii <eliz@gnu.org>
parents: 28467
diff changeset
75 a color-capable display."
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
76 :options '(light dark mono nil)
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
77 :type 'symbol
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
78 :group 'cpp)
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
79
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
80 (defcustom cpp-known-writable t
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
81 "*Non-nil means you are allowed to modify the known conditionals."
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
82 :type 'boolean
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
83 :group 'cpp)
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
84
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
85 (defcustom cpp-unknown-writable t
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
86 "*Non-nil means you are allowed to modify the unknown conditionals."
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
87 :type 'boolean
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
88 :group 'cpp)
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
89
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
90 (defcustom cpp-edit-list nil
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
91 "Alist of cpp macros and information about how they should be displayed.
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
92 Each entry is a list with the following elements:
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
93 0. The name of the macro (a string).
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
94 1. Face used for text that is `ifdef' the macro.
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
95 2. Face used for text that is `ifndef' the macro.
50858
54347668e2e9 (cpp-edit-list): Don't quote nil and t in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 49598
diff changeset
96 3. t, nil, or `both' depending on what text may be edited."
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
97 :type '(repeat (list string face face
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
98 (choice (const t)
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
99 (const nil)
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
100 (const both))))
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
101 :group 'cpp)
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
102
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
103 (defvar cpp-overlay-list nil)
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
104 ;; List of cpp overlays active in the current buffer.
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
105 (make-variable-buffer-local 'cpp-overlay-list)
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
106
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
107 (defvar cpp-callback-data)
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
108 (defvar cpp-state-stack)
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
109
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
110 (defconst cpp-face-type-list
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
111 '(("light color background" . light)
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
112 ("dark color background" . dark)
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
113 ("monochrome" . mono)
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
114 ("tty" . none))
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
115 "Alist of strings and names of the defined face collections.")
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
116
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
117 (defconst cpp-writable-list
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
118 ;; Names used for the writable property.
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
119 '(("writable" . t)
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
120 ("read-only" . nil)))
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
121
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
122 (defvar cpp-button-event nil)
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
123 ;; This will be t in the callback for `cpp-make-button'.
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
124
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
125 (defvar cpp-edit-buffer nil)
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
126 ;; Real buffer whose cpp display information we are editing.
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
127 (make-variable-buffer-local 'cpp-edit-buffer)
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
128
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
129 (defconst cpp-branch-list
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
130 ;; Alist of branches.
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
131 '(("false" . nil)
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
132 ("true" . t)
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
133 ("both" . both)))
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
134
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
135 (defcustom cpp-face-default-list nil
19129
35d85b50c3cb (cpp-create-bg-face): Don't really make a face.
Richard M. Stallman <rms@gnu.org>
parents: 19009
diff changeset
136 "Alist of faces you can choose from for cpp conditionals.
35d85b50c3cb (cpp-create-bg-face): Don't really make a face.
Richard M. Stallman <rms@gnu.org>
parents: 19009
diff changeset
137 Each element has the form (STRING . FACE), where STRING
35d85b50c3cb (cpp-create-bg-face): Don't really make a face.
Richard M. Stallman <rms@gnu.org>
parents: 19009
diff changeset
138 serves as a name (for `cpp-highlight-buffer' only)
35d85b50c3cb (cpp-create-bg-face): Don't really make a face.
Richard M. Stallman <rms@gnu.org>
parents: 19009
diff changeset
139 and FACE is either a face (a symbol)
35d85b50c3cb (cpp-create-bg-face): Don't really make a face.
Richard M. Stallman <rms@gnu.org>
parents: 19009
diff changeset
140 or a cons cell (background-color . COLOR)."
35d85b50c3cb (cpp-create-bg-face): Don't really make a face.
Richard M. Stallman <rms@gnu.org>
parents: 19009
diff changeset
141 :type '(repeat (cons string (choice face (cons (const background-color) string))))
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
142 :group 'cpp)
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
143
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
144 (defcustom cpp-face-light-name-list
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
145 '("light gray" "light blue" "light cyan" "light yellow" "light pink"
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
146 "pale green" "beige" "orange" "magenta" "violet" "medium purple"
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
147 "turquoise")
63275
7c5cfb705766 (cpp-face-light-name-list, cpp-face-dark-name-list): Fix spellings in
Juanma Barranquero <lekktu@gmail.com>
parents: 52401
diff changeset
148 "Background colors useful with dark foreground colors."
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
149 :type '(repeat string)
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
150 :group 'cpp)
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
151
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
152 (defcustom cpp-face-dark-name-list
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
153 '("dim gray" "blue" "cyan" "yellow" "red"
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
154 "dark green" "brown" "dark orange" "dark khaki" "dark violet" "purple"
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
155 "dark turquoise")
63275
7c5cfb705766 (cpp-face-light-name-list, cpp-face-dark-name-list): Fix spellings in
Juanma Barranquero <lekktu@gmail.com>
parents: 52401
diff changeset
156 "Background colors useful with light foreground colors."
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
157 :type '(repeat string)
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
158 :group 'cpp)
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
159
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
160 (defcustom cpp-face-light-list nil
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
161 "Alist of names and faces to be used for light backgrounds."
23271
f3d8ff8877ff (cpp-face-light-list, cpp-face-dark-list): Fix
Andreas Schwab <schwab@suse.de>
parents: 19130
diff changeset
162 :type '(repeat (cons string (choice face
f3d8ff8877ff (cpp-face-light-list, cpp-face-dark-list): Fix
Andreas Schwab <schwab@suse.de>
parents: 19130
diff changeset
163 (cons (const background-color) string))))
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
164 :group 'cpp)
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
165
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
166 (defcustom cpp-face-dark-list nil
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
167 "Alist of names and faces to be used for dark backgrounds."
23271
f3d8ff8877ff (cpp-face-light-list, cpp-face-dark-list): Fix
Andreas Schwab <schwab@suse.de>
parents: 19130
diff changeset
168 :type '(repeat (cons string (choice face
f3d8ff8877ff (cpp-face-light-list, cpp-face-dark-list): Fix
Andreas Schwab <schwab@suse.de>
parents: 19130
diff changeset
169 (cons (const background-color) string))))
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
170 :group 'cpp)
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
171
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
172 (defcustom cpp-face-mono-list
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
173 '(("bold" . bold)
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
174 ("bold-italic" . bold-italic)
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
175 ("italic" . italic)
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
176 ("underline" . underline))
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
177 "Alist of names and faces to be used for monochrome screens."
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
178 :type '(repeat (cons string face))
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
179 :group 'cpp)
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
180
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
181 (defcustom cpp-face-none-list
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
182 '(("default" . default)
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
183 ("invisible" . invisible))
19009
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
184 "Alist of names and faces available even if you don't use a window system."
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
185 :type '(repeat (cons string face))
1493fc19f324 Customized.
Richard M. Stallman <rms@gnu.org>
parents: 18071
diff changeset
186 :group 'cpp)
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
187
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
188 (defvar cpp-face-all-list
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
189 (append cpp-face-light-list
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
190 cpp-face-dark-list
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
191 cpp-face-mono-list
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
192 cpp-face-none-list)
13974
37cfc82fe02d (cpp-unknown-face, cpp-face-mono-list, cpp-face-all-list):
Karl Heuer <kwzh@gnu.org>
parents: 13911
diff changeset
193 "All faces used for highlighting text inside cpp conditionals.")
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
194
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
195 ;;; Parse Buffer:
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
196
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
197 (defvar cpp-parse-symbols nil
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
198 "List of cpp macros used in the local buffer.")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
199 (make-variable-buffer-local 'cpp-parse-symbols)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
200
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
201 (defconst cpp-parse-regexp
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
202 ;; Regexp matching all tokens needed to find conditionals.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
203 (concat
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
204 "'\\|\"\\|/\\*\\|//\\|"
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
205 "\\(^[ \t]*#[ \t]*\\(ifdef\\|ifndef\\|if\\|"
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
206 "elif\\|else\\|endif\\)\\b\\)"))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
207
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
208 ;;;###autoload
8741
9728aab0cab3 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 8740
diff changeset
209 (defun cpp-highlight-buffer (arg)
9728aab0cab3 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 8740
diff changeset
210 "Highlight C code according to preprocessor conditionals.
9728aab0cab3 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 8740
diff changeset
211 This command pops up a buffer which you should edit to specify
9728aab0cab3 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 8740
diff changeset
212 what kind of highlighting to use, and the criteria for highlighting.
11456
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
213 A prefix arg suppresses display of that buffer."
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
214 (interactive "P")
19129
35d85b50c3cb (cpp-create-bg-face): Don't really make a face.
Richard M. Stallman <rms@gnu.org>
parents: 19009
diff changeset
215 (unless (or (eq t buffer-invisibility-spec)
35d85b50c3cb (cpp-create-bg-face): Don't really make a face.
Richard M. Stallman <rms@gnu.org>
parents: 19009
diff changeset
216 (memq 'cpp buffer-invisibility-spec))
18071
bcdf720abb1a (cpp-highlight-buffer): Make sure
Richard M. Stallman <rms@gnu.org>
parents: 17981
diff changeset
217 (add-to-invisibility-spec 'cpp))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
218 (setq cpp-parse-symbols nil)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
219 (cpp-parse-reset)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
220 (if (null cpp-edit-list)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
221 (cpp-edit-load))
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
222 (let (cpp-state-stack)
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
223 (save-excursion
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
224 (goto-char (point-min))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
225 (cpp-progress-message "Parsing...")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
226 (while (re-search-forward cpp-parse-regexp nil t)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
227 (cpp-progress-message "Parsing...%d%%"
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
228 (/ (* 100 (- (point) (point-min))) (buffer-size)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
229 (let ((match (buffer-substring (match-beginning 0) (match-end 0))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
230 (cond ((or (string-equal match "'")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
231 (string-equal match "\""))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
232 (goto-char (match-beginning 0))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
233 (condition-case nil
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
234 (forward-sexp)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
235 (error (cpp-parse-error
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
236 "Unterminated string or character"))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
237 ((string-equal match "/*")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
238 (or (search-forward "*/" nil t)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
239 (error "Unterminated comment")))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
240 ((string-equal match "//")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
241 (skip-chars-forward "^\n\r"))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
242 (t
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
243 (end-of-line 1)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
244 (let ((from (match-beginning 1))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
245 (to (1+ (point)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
246 (type (buffer-substring (match-beginning 2)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
247 (match-end 2)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
248 (expr (buffer-substring (match-end 1) (point))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
249 (cond ((string-equal type "ifdef")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
250 (cpp-parse-open t expr from to))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
251 ((string-equal type "ifndef")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
252 (cpp-parse-open nil expr from to))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
253 ((string-equal type "if")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
254 (cpp-parse-open t expr from to))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
255 ((string-equal type "elif")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
256 (let (cpp-known-face cpp-unknown-face)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
257 (cpp-parse-close from to))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
258 (cpp-parse-open t expr from to))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
259 ((string-equal type "else")
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
260 (or cpp-state-stack
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
261 (cpp-parse-error "Top level #else"))
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
262 (let ((entry (list (not (nth 0 (car cpp-state-stack)))
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
263 (nth 1 (car cpp-state-stack))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
264 from to)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
265 (cpp-parse-close from to)
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
266 (setq cpp-state-stack (cons entry cpp-state-stack))))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
267 ((string-equal type "endif")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
268 (cpp-parse-close from to))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
269 (t
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
270 (cpp-parse-error "Parser error"))))))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
271 (message "Parsing...done"))
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
272 (if cpp-state-stack
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
273 (save-excursion
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
274 (goto-char (nth 3 (car cpp-state-stack)))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
275 (cpp-parse-error "Unclosed conditional"))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
276 (or arg
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
277 (null cpp-parse-symbols)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
278 (cpp-parse-edit)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
279
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
280 (defun cpp-parse-open (branch expr begin end)
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
281 "Push information about conditional-beginning onto `cpp-state-stack'."
11456
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
282 ;; Discard comments within this line.
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
283 (while (string-match "\\b[ \t]*/\\*.*\\*/[ \t]*\\b" expr)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
284 (setq expr (concat (substring expr 0 (match-beginning 0))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
285 (substring expr (match-end 0)))))
11456
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
286 ;; If a comment starts on this line and continues past, discard it.
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
287 (if (string-match "\\b[ \t]*/\\*" expr)
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
288 (setq expr (substring expr 0 (match-beginning 0))))
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
289 ;; Delete any C++ comment from the line.
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
290 (if (string-match "\\b[ \t]*\\(//.*\\)?$" expr)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
291 (setq expr (substring expr 0 (match-beginning 0))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
292 (while (string-match "[ \t]+" expr)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
293 (setq expr (concat (substring expr 0 (match-beginning 0))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
294 (substring expr (match-end 0)))))
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
295 (setq cpp-state-stack (cons (list branch expr begin end) cpp-state-stack))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
296 (or (member expr cpp-parse-symbols)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
297 (setq cpp-parse-symbols
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
298 (cons expr cpp-parse-symbols)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
299 (if (assoc expr cpp-edit-list)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
300 (cpp-make-known-overlay begin end)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
301 (cpp-make-unknown-overlay begin end)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
302
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
303 (defun cpp-parse-close (from to)
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
304 ;; Pop top of cpp-state-stack and create overlay.
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
305 (let ((entry (assoc (nth 1 (car cpp-state-stack)) cpp-edit-list))
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
306 (branch (nth 0 (car cpp-state-stack)))
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
307 (begin (nth 2 (car cpp-state-stack)))
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
308 (end (nth 3 (car cpp-state-stack))))
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
309 (setq cpp-state-stack (cdr cpp-state-stack))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
310 (if entry
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
311 (let ((face (nth (if branch 1 2) entry))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
312 (read-only (eq (not branch) (nth 3 entry)))
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
313 (priority (length cpp-state-stack))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
314 (overlay (make-overlay end from)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
315 (cpp-make-known-overlay from to)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
316 (setq cpp-overlay-list (cons overlay cpp-overlay-list))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
317 (if priority (overlay-put overlay 'priority priority))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
318 (cond ((eq face 'invisible)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
319 (cpp-make-overlay-hidden overlay))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
320 ((eq face 'default))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
321 (t
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
322 (overlay-put overlay 'face face)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
323 (if read-only
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
324 (cpp-make-overlay-read-only overlay)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
325 (cpp-make-overlay-sticky overlay)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
326 (cpp-make-unknown-overlay from to))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
327
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
328 (defun cpp-parse-error (error)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
329 ;; Error message issued by the cpp parser.
14417
2b2e0cef30d5 (cpp-parse-error): Fix error format string.
Karl Heuer <kwzh@gnu.org>
parents: 14169
diff changeset
330 (error "%s at line %d" error (count-lines (point-min) (point))))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
331
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
332 (defun cpp-parse-reset ()
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
333 "Reset display of cpp conditionals to normal."
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
334 (interactive)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
335 (while cpp-overlay-list
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
336 (delete-overlay (car cpp-overlay-list))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
337 (setq cpp-overlay-list (cdr cpp-overlay-list))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
338
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
339 ;;;###autoload
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
340 (defun cpp-parse-edit ()
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
341 "Edit display information for cpp conditionals."
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
342 (interactive)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
343 (or cpp-parse-symbols
11456
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
344 (cpp-highlight-buffer t))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
345 (let ((buffer (current-buffer)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
346 (pop-to-buffer "*CPP Edit*")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
347 (cpp-edit-mode)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
348 (setq cpp-edit-buffer buffer)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
349 (cpp-edit-reset)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
350
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
351 ;;; Overlays:
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
352
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
353 (defun cpp-make-known-overlay (start end)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
354 ;; Create an overlay for a known cpp command from START to END.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
355 (let ((overlay (make-overlay start end)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
356 (if (eq cpp-known-face 'invisible)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
357 (cpp-make-overlay-hidden overlay)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
358 (or (eq cpp-known-face 'default)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
359 (overlay-put overlay 'face cpp-known-face))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
360 (if cpp-known-writable
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
361 ()
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
362 (overlay-put overlay 'modification-hooks '(cpp-signal-read-only))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
363 (overlay-put overlay 'insert-in-front-hooks '(cpp-signal-read-only))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
364 (setq cpp-overlay-list (cons overlay cpp-overlay-list))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
365
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
366 (defun cpp-make-unknown-overlay (start end)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
367 ;; Create an overlay for an unknown cpp command from START to END.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
368 (let ((overlay (make-overlay start end)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
369 (cond ((eq cpp-unknown-face 'invisible)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
370 (cpp-make-overlay-hidden overlay))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
371 ((eq cpp-unknown-face 'default))
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 45431
diff changeset
372 (t
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
373 (overlay-put overlay 'face cpp-unknown-face)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
374 (if cpp-unknown-writable
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
375 ()
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
376 (overlay-put overlay 'modification-hooks '(cpp-signal-read-only))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
377 (overlay-put overlay 'insert-in-front-hooks '(cpp-signal-read-only)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
378 (setq cpp-overlay-list (cons overlay cpp-overlay-list))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
379
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
380 (defun cpp-make-overlay-hidden (overlay)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
381 ;; Make overlay hidden and intangible.
18071
bcdf720abb1a (cpp-highlight-buffer): Make sure
Richard M. Stallman <rms@gnu.org>
parents: 17981
diff changeset
382 (overlay-put overlay 'invisible 'cpp)
11492
2e09c796bf70 (cpp-edit-reset): Fix typo.
Richard M. Stallman <rms@gnu.org>
parents: 11480
diff changeset
383 (overlay-put overlay 'modification-hooks '(cpp-signal-read-only))
2e09c796bf70 (cpp-edit-reset): Fix typo.
Richard M. Stallman <rms@gnu.org>
parents: 11480
diff changeset
384 (overlay-put overlay 'insert-in-front-hooks '(cpp-signal-read-only)))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
385
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
386 (defun cpp-make-overlay-read-only (overlay)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
387 ;; Make overlay read only.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
388 (overlay-put overlay 'modification-hooks '(cpp-signal-read-only))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
389 (overlay-put overlay 'insert-in-front-hooks '(cpp-signal-read-only))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
390 (overlay-put overlay 'insert-behind-hooks '(cpp-signal-read-only)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
391
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
392 (defun cpp-make-overlay-sticky (overlay)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
393 ;; Make OVERLAY grow when you insert text at either end.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
394 (overlay-put overlay 'insert-in-front-hooks '(cpp-grow-overlay))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
395 (overlay-put overlay 'insert-behind-hooks '(cpp-grow-overlay)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
396
11492
2e09c796bf70 (cpp-edit-reset): Fix typo.
Richard M. Stallman <rms@gnu.org>
parents: 11480
diff changeset
397 (defun cpp-signal-read-only (overlay after start end &optional len)
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
398 ;; Only allow deleting the whole overlay.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
399 ;; Trying to change a read-only overlay.
11492
2e09c796bf70 (cpp-edit-reset): Fix typo.
Richard M. Stallman <rms@gnu.org>
parents: 11480
diff changeset
400 (if (and (not after)
2e09c796bf70 (cpp-edit-reset): Fix typo.
Richard M. Stallman <rms@gnu.org>
parents: 11480
diff changeset
401 (or (< (overlay-start overlay) start)
2e09c796bf70 (cpp-edit-reset): Fix typo.
Richard M. Stallman <rms@gnu.org>
parents: 11480
diff changeset
402 (> (overlay-end overlay) end)))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
403 (error "This text is read only")))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
404
11492
2e09c796bf70 (cpp-edit-reset): Fix typo.
Richard M. Stallman <rms@gnu.org>
parents: 11480
diff changeset
405 (defun cpp-grow-overlay (overlay after start end &optional len)
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
406 ;; Make OVERLAY grow to contain range START to END.
11492
2e09c796bf70 (cpp-edit-reset): Fix typo.
Richard M. Stallman <rms@gnu.org>
parents: 11480
diff changeset
407 (if after
2e09c796bf70 (cpp-edit-reset): Fix typo.
Richard M. Stallman <rms@gnu.org>
parents: 11480
diff changeset
408 (move-overlay overlay
2e09c796bf70 (cpp-edit-reset): Fix typo.
Richard M. Stallman <rms@gnu.org>
parents: 11480
diff changeset
409 (min start (overlay-start overlay))
2e09c796bf70 (cpp-edit-reset): Fix typo.
Richard M. Stallman <rms@gnu.org>
parents: 11480
diff changeset
410 (max end (overlay-end overlay)))))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
411
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
412 ;;; Edit Buffer:
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
413
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
414 (defvar cpp-edit-map nil)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
415 ;; Keymap for `cpp-edit-mode'.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
416
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
417 (if cpp-edit-map
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
418 ()
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
419 (setq cpp-edit-map (make-keymap))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
420 (suppress-keymap cpp-edit-map)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
421 (define-key cpp-edit-map [ down-mouse-2 ] 'cpp-push-button)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
422 (define-key cpp-edit-map [ mouse-2 ] 'ignore)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
423 (define-key cpp-edit-map " " 'scroll-up)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
424 (define-key cpp-edit-map "\C-?" 'scroll-down)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
425 (define-key cpp-edit-map [ delete ] 'scroll-down)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
426 (define-key cpp-edit-map "\C-c\C-c" 'cpp-edit-apply)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
427 (define-key cpp-edit-map "a" 'cpp-edit-apply)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
428 (define-key cpp-edit-map "A" 'cpp-edit-apply)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
429 (define-key cpp-edit-map "r" 'cpp-edit-reset)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
430 (define-key cpp-edit-map "R" 'cpp-edit-reset)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
431 (define-key cpp-edit-map "s" 'cpp-edit-save)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
432 (define-key cpp-edit-map "S" 'cpp-edit-save)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
433 (define-key cpp-edit-map "l" 'cpp-edit-load)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
434 (define-key cpp-edit-map "L" 'cpp-edit-load)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
435 (define-key cpp-edit-map "h" 'cpp-edit-home)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
436 (define-key cpp-edit-map "H" 'cpp-edit-home)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
437 (define-key cpp-edit-map "b" 'cpp-edit-background)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
438 (define-key cpp-edit-map "B" 'cpp-edit-background)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
439 (define-key cpp-edit-map "k" 'cpp-edit-known)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
440 (define-key cpp-edit-map "K" 'cpp-edit-known)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
441 (define-key cpp-edit-map "u" 'cpp-edit-unknown)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
442 (define-key cpp-edit-map "u" 'cpp-edit-unknown)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
443 (define-key cpp-edit-map "t" 'cpp-edit-true)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
444 (define-key cpp-edit-map "T" 'cpp-edit-true)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
445 (define-key cpp-edit-map "f" 'cpp-edit-false)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
446 (define-key cpp-edit-map "F" 'cpp-edit-false)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
447 (define-key cpp-edit-map "w" 'cpp-edit-write)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
448 (define-key cpp-edit-map "W" 'cpp-edit-write)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
449 (define-key cpp-edit-map "X" 'cpp-edit-toggle-known)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
450 (define-key cpp-edit-map "x" 'cpp-edit-toggle-known)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
451 (define-key cpp-edit-map "Y" 'cpp-edit-toggle-unknown)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
452 (define-key cpp-edit-map "y" 'cpp-edit-toggle-unknown)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
453 (define-key cpp-edit-map "q" 'bury-buffer)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
454 (define-key cpp-edit-map "Q" 'bury-buffer))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
455
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
456 (defvar cpp-edit-symbols nil)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
457 ;; Symbols defined in the edit buffer.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
458 (make-variable-buffer-local 'cpp-edit-symbols)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
459
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
460 (defun cpp-edit-mode ()
8741
9728aab0cab3 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 8740
diff changeset
461 "Major mode for editing the criteria for highlighting cpp conditionals.
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 45431
diff changeset
462 Click on objects to change them.
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
463 You can also use the keyboard accelerators indicated like this: [K]ey."
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
464 (kill-all-local-variables)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
465 (buffer-disable-undo)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
466 (auto-save-mode -1)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
467 (setq buffer-read-only t)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
468 (setq major-mode 'cpp-edit-mode)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
469 (setq mode-name "CPP Edit")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
470 (use-local-map cpp-edit-map))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
471
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
472 (defun cpp-edit-apply ()
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
473 "Apply edited display information to original buffer."
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
474 (interactive)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
475 (cpp-edit-home)
11456
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
476 (cpp-highlight-buffer t))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
477
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
478 (defun cpp-edit-reset ()
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
479 "Reset display information from original buffer."
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
480 (interactive)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
481 (let ((buffer (current-buffer))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
482 (buffer-read-only nil)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
483 (start (window-start))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
484 (pos (point))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
485 symbols)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
486 (set-buffer cpp-edit-buffer)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
487 (setq symbols cpp-parse-symbols)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
488 (set-buffer buffer)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
489 (setq cpp-edit-symbols symbols)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
490 (erase-buffer)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
491 (insert "CPP Display Information for `")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
492 (cpp-make-button (buffer-name cpp-edit-buffer) 'cpp-edit-home)
19130
0c228cae75b5 (cpp-edit-reset): Add a close-quote after the file name.
Richard M. Stallman <rms@gnu.org>
parents: 19129
diff changeset
493 (insert "'\n\nClick mouse-2 on item you want to change or use\n"
11456
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
494 "or switch to this buffer and type the keyboard equivalents.\n"
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
495 "Keyboard equivalents are indicated with brackets like [T]his.\n\n")
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
496 (cpp-make-button "[H]ome (display the C file)" 'cpp-edit-home)
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
497 (insert " ")
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
498 (cpp-make-button "[A]pply new settings" 'cpp-edit-apply)
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
499 (insert "\n")
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
500 (cpp-make-button "[S]ave settings" 'cpp-edit-save)
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
501 (insert " ")
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
502 (cpp-make-button "[L]oad settings" 'cpp-edit-load)
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
503 (insert "\n\n")
0950bf9c8d06 (cpp-parse-open): Delete comments that go past end of line.
Richard M. Stallman <rms@gnu.org>
parents: 8741
diff changeset
504
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
505 (insert "[B]ackground: ")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
506 (cpp-make-button (car (rassq cpp-face-type cpp-face-type-list))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
507 'cpp-edit-background)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
508 (insert "\n[K]nown conditionals: ")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
509 (cpp-make-button (cpp-face-name cpp-known-face)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
510 'cpp-edit-known nil t)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
511 (insert " [X] ")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
512 (cpp-make-button (car (rassq cpp-known-writable cpp-writable-list))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
513 'cpp-edit-toggle-known)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
514 (insert "\n[U]nknown conditionals: ")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
515 (cpp-make-button (cpp-face-name cpp-unknown-face)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
516 'cpp-edit-unknown nil t)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
517 (insert " [Y] ")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
518 (cpp-make-button (car (rassq cpp-unknown-writable cpp-writable-list))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
519 'cpp-edit-toggle-unknown)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
520 (insert (format "\n\n\n%39s: %14s %14s %7s\n\n" "Expression"
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
521 "[T]rue Face" "[F]alse Face" "[W]rite"))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
522 (while symbols
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
523 (let* ((symbol (car symbols))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
524 (entry (assoc symbol cpp-edit-list))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
525 (true (nth 1 entry))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
526 (false (nth 2 entry))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
527 (write (if entry (nth 3 entry) 'both)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
528 (setq symbols (cdr symbols))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
529
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
530 (if (and entry ; Make default entries unknown.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
531 (or (null true) (eq true 'default))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
532 (or (null false) (eq false 'default))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
533 (eq write 'both))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
534 (setq cpp-edit-list (delq entry cpp-edit-list)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
535 entry nil))
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 45431
diff changeset
536
11492
2e09c796bf70 (cpp-edit-reset): Fix typo.
Richard M. Stallman <rms@gnu.org>
parents: 11480
diff changeset
537 (if (> (length symbol) 39)
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
538 (insert (substring symbol 0 39) ": ")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
539 (insert (format "%39s: " symbol)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
540
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
541 (cpp-make-button (cpp-face-name true)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
542 'cpp-edit-true symbol t 14)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
543 (insert " ")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
544 (cpp-make-button (cpp-face-name false)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
545 'cpp-edit-false symbol t 14)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
546 (insert " ")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
547 (cpp-make-button (car (rassq write cpp-branch-list))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
548 'cpp-edit-write symbol nil 6)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
549 (insert "\n")))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
550 (insert "\n\n")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
551 (set-window-start nil start)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
552 (goto-char pos)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
553
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
554 (defun cpp-edit-load ()
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
555 "Load cpp configuration."
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
556 (interactive)
16681
58b38425b463 (cpp-edit-load): Don't load anything if init-file-user is nil.
Richard M. Stallman <rms@gnu.org>
parents: 14417
diff changeset
557 (cond ((null init-file-user)
58b38425b463 (cpp-edit-load): Don't load anything if init-file-user is nil.
Richard M. Stallman <rms@gnu.org>
parents: 14417
diff changeset
558 ;; If -q was specified, don't load any init files.
58b38425b463 (cpp-edit-load): Don't load anything if init-file-user is nil.
Richard M. Stallman <rms@gnu.org>
parents: 14417
diff changeset
559 nil)
58b38425b463 (cpp-edit-load): Don't load anything if init-file-user is nil.
Richard M. Stallman <rms@gnu.org>
parents: 14417
diff changeset
560 ((file-readable-p cpp-config-file)
13911
3e9e8b468bc1 (cpp-config-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11492
diff changeset
561 (load-file cpp-config-file))
3e9e8b468bc1 (cpp-config-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11492
diff changeset
562 ((file-readable-p (concat "~/" cpp-config-file))
3e9e8b468bc1 (cpp-config-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11492
diff changeset
563 (load-file cpp-config-file)))
8740
714588372e06 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 8736
diff changeset
564 (if (eq major-mode 'cpp-edit-mode)
714588372e06 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 8736
diff changeset
565 (cpp-edit-reset)))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
566
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
567 (defun cpp-edit-save ()
16681
58b38425b463 (cpp-edit-load): Don't load anything if init-file-user is nil.
Richard M. Stallman <rms@gnu.org>
parents: 14417
diff changeset
568 "Save the current cpp configuration in a file."
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
569 (interactive)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
570 (require 'pp)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
571 (save-excursion
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
572 (set-buffer cpp-edit-buffer)
13911
3e9e8b468bc1 (cpp-config-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11492
diff changeset
573 (let ((buffer (find-file-noselect cpp-config-file)))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
574 (set-buffer buffer)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
575 (erase-buffer)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
576 (pp (list 'setq 'cpp-known-face
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
577 (list 'quote cpp-known-face)) buffer)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
578 (pp (list 'setq 'cpp-unknown-face
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
579 (list 'quote cpp-unknown-face)) buffer)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
580 (pp (list 'setq 'cpp-face-type
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
581 (list 'quote cpp-face-type)) buffer)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
582 (pp (list 'setq 'cpp-known-writable
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
583 (list 'quote cpp-known-writable)) buffer)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
584 (pp (list 'setq 'cpp-unknown-writable
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
585 (list 'quote cpp-unknown-writable)) buffer)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
586 (pp (list 'setq 'cpp-edit-list
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
587 (list 'quote cpp-edit-list)) buffer)
13911
3e9e8b468bc1 (cpp-config-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11492
diff changeset
588 (write-file cpp-config-file))))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
589
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
590 (defun cpp-edit-home ()
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
591 "Switch back to original buffer."
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
592 (interactive)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
593 (if cpp-button-event
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
594 (read-event))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
595 (pop-to-buffer cpp-edit-buffer))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
596
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
597 (defun cpp-edit-background ()
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
598 "Change default face collection."
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
599 (interactive)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
600 (call-interactively 'cpp-choose-default-face)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
601 (cpp-edit-reset))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
602
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
603 (defun cpp-edit-known ()
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
604 "Select default for known conditionals."
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
605 (interactive)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
606 (setq cpp-known-face (cpp-choose-face "Known face" cpp-known-face))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
607 (cpp-edit-reset))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
608
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
609 (defun cpp-edit-unknown ()
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
610 "Select default for unknown conditionals."
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
611 (interactive)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
612 (setq cpp-unknown-face (cpp-choose-face "Unknown face" cpp-unknown-face))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
613 (cpp-edit-reset))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
614
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
615 (defun cpp-edit-toggle-known (arg)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
616 "Toggle writable status for known conditionals.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
617 With optional argument ARG, make them writable iff ARG is positive."
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
618 (interactive "@P")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
619 (if (or (and (null arg) cpp-known-writable)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
620 (<= (prefix-numeric-value arg) 0))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
621 (setq cpp-known-writable nil)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
622 (setq cpp-known-writable t))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
623 (cpp-edit-reset))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
624
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
625 (defun cpp-edit-toggle-unknown (arg)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
626 "Toggle writable status for unknown conditionals.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
627 With optional argument ARG, make them writable iff ARG is positive."
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
628 (interactive "@P")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
629 (if (or (and (null arg) cpp-unknown-writable)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
630 (<= (prefix-numeric-value arg) 0))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
631 (setq cpp-unknown-writable nil)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
632 (setq cpp-unknown-writable t))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
633 (cpp-edit-reset))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
634
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
635 (defun cpp-edit-true (symbol face)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
636 "Select SYMBOL's true FACE used for highlighting taken conditionals."
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
637 (interactive
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
638 (let ((symbol (cpp-choose-symbol)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
639 (list symbol
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
640 (cpp-choose-face "True face"
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
641 (nth 1 (assoc symbol cpp-edit-list))))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
642 (setcar (nthcdr 1 (cpp-edit-list-entry-get-or-create symbol)) face)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
643 (cpp-edit-reset))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
644
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
645 (defun cpp-edit-false (symbol face)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
646 "Select SYMBOL's false FACE used for highlighting untaken conditionals."
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
647 (interactive
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
648 (let ((symbol (cpp-choose-symbol)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
649 (list symbol
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 45431
diff changeset
650 (cpp-choose-face "False face"
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
651 (nth 2 (assoc symbol cpp-edit-list))))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
652 (setcar (nthcdr 2 (cpp-edit-list-entry-get-or-create symbol)) face)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
653 (cpp-edit-reset))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
654
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
655 (defun cpp-edit-write (symbol branch)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
656 "Set which branches of SYMBOL should be writable to BRANCH.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
657 BRANCH should be either nil (false branch), t (true branch) or 'both."
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
658 (interactive (list (cpp-choose-symbol) (cpp-choose-branch)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
659 (setcar (nthcdr 3 (cpp-edit-list-entry-get-or-create symbol)) branch)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
660 (cpp-edit-reset))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
661
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
662 (defun cpp-edit-list-entry-get-or-create (symbol)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
663 ;; Return the entry for SYMBOL in `cpp-edit-list'.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
664 ;; If it does not exist, create it.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
665 (let ((entry (assoc symbol cpp-edit-list)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
666 (or entry
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
667 (setq entry (list symbol nil nil 'both nil)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
668 cpp-edit-list (cons entry cpp-edit-list)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
669 entry))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
670
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
671 ;;; Prompts:
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
672
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
673 (defun cpp-choose-symbol ()
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
674 ;; Choose a symbol if called from keyboard, otherwise use the one clicked on.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
675 (if cpp-button-event
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
676 cpp-callback-data
45431
7505ed4a9b60 (cpp-choose-symbol): Don't cons unnecessarily.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40955
diff changeset
677 (completing-read "Symbol: " cpp-edit-symbols nil t)))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
678
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
679 (defun cpp-choose-branch ()
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
680 ;; Choose a branch, either nil, t, or both.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
681 (if cpp-button-event
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
682 (x-popup-menu cpp-button-event
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
683 (list "Branch" (cons "Branch" cpp-branch-list)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
684 (cdr (assoc (completing-read "Branch: " cpp-branch-list nil t)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
685 cpp-branch-list))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
686
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
687 (defun cpp-choose-face (prompt default)
40955
eb0bdaed72a8 (cpp-choose-face): Fix typo.
Pavel Janík <Pavel@Janik.cz>
parents: 38436
diff changeset
688 ;; Choose a face from cpp-face-default-list.
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
689 ;; PROMPT is what to say to the user.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
690 ;; DEFAULT is the default face.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
691 (or (if cpp-button-event
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
692 (x-popup-menu cpp-button-event
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
693 (list prompt (cons prompt cpp-face-default-list)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
694 (let ((name (car (rassq default cpp-face-default-list))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
695 (cdr (assoc (completing-read (if name
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
696 (concat prompt
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
697 " (default " name "): ")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
698 (concat prompt ": "))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
699 cpp-face-default-list nil t)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
700 cpp-face-all-list))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
701 default))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
702
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
703 (defun cpp-choose-default-face (type)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
704 ;; Choose default face list for screen of TYPE.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
705 ;; Type must be one of the types defined in `cpp-face-type-list'.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
706 (interactive (list (if cpp-button-event
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
707 (x-popup-menu cpp-button-event
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
708 (list "Screen type"
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
709 (cons "Screen type"
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
710 cpp-face-type-list)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
711 (cdr (assoc (completing-read "Screen type: "
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
712 cpp-face-type-list
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
713 nil t)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
714 cpp-face-type-list)))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
715 (cond ((null type))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
716 ((eq type 'light)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
717 (if cpp-face-light-list
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
718 ()
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
719 (setq cpp-face-light-list
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
720 (mapcar 'cpp-create-bg-face cpp-face-light-name-list))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
721 (setq cpp-face-all-list
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
722 (append cpp-face-all-list cpp-face-light-list)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
723 (setq cpp-face-type 'light)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
724 (setq cpp-face-default-list
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
725 (append cpp-face-light-list cpp-face-none-list)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
726 ((eq type 'dark)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
727 (if cpp-face-dark-list
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
728 ()
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
729 (setq cpp-face-dark-list
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
730 (mapcar 'cpp-create-bg-face cpp-face-dark-name-list))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
731 (setq cpp-face-all-list
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
732 (append cpp-face-all-list cpp-face-dark-list)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
733 (setq cpp-face-type 'dark)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
734 (setq cpp-face-default-list
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
735 (append cpp-face-dark-list cpp-face-none-list)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
736 ((eq type 'mono)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
737 (setq cpp-face-type 'mono)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
738 (setq cpp-face-default-list
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
739 (append cpp-face-mono-list cpp-face-none-list)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
740 (t
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
741 (setq cpp-face-type 'none)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
742 (setq cpp-face-default-list cpp-face-none-list))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
743
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
744 ;;; Buttons:
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
745
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
746 (defun cpp-make-button (name callback &optional data face padding)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
747 ;; Create a button at point.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
748 ;; NAME is the name of the button.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
749 ;; CALLBACK is the function to call when the button is pushed.
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
750 ;; DATA will be made available to CALLBACK
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
751 ;;in the free variable cpp-callback-data.
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
752 ;; FACE means that NAME is the name of a face in `cpp-face-all-list'.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
753 ;; PADDING means NAME will be right justified at that length.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
754 (let ((name (format "%s" name))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
755 from to)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
756 (cond ((null padding)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
757 (setq from (point))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
758 (insert name))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
759 ((> (length name) padding)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
760 (setq from (point))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
761 (insert (substring name 0 padding)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
762 (t
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
763 (insert (make-string (- padding (length name)) ? ))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
764 (setq from (point))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
765 (insert name)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
766 (setq to (point))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
767 (setq face
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
768 (if face
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
769 (let ((check (cdr (assoc name cpp-face-all-list))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
770 (if (memq check '(default invisible))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
771 'bold
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
772 check))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
773 'bold))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
774 (add-text-properties from to
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
775 (append (list 'face face)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
776 '(mouse-face highlight)
38078
8bc0292b0367 (cpp-make-button): Add help-echo to mouse-highlighted text.
Eli Zaretskii <eliz@gnu.org>
parents: 30541
diff changeset
777 '(help-echo "mouse-2: change/use this item")
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
778 (list 'cpp-callback callback)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
779 (if data (list 'cpp-data data))))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
780
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
781 (defun cpp-push-button (event)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
782 ;; Pushed a CPP button.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
783 (interactive "@e")
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
784 (set-buffer (window-buffer (posn-window (event-start event))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
785 (let ((pos (posn-point (event-start event))))
11480
5865f4bc9521 (cpp-edit-list): Move definition toward start of file.
Richard M. Stallman <rms@gnu.org>
parents: 11456
diff changeset
786 (let ((cpp-callback-data (get-text-property pos 'cpp-data))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
787 (fun (get-text-property pos 'cpp-callback))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
788 (cpp-button-event event))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
789 (cond (fun
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
790 (call-interactively (get-text-property pos 'cpp-callback)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
791 ((lookup-key global-map [ down-mouse-2])
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
792 (call-interactively (lookup-key global-map [ down-mouse-2])))))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
793
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
794 ;;; Faces:
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
795
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
796 (defun cpp-create-bg-face (color)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
797 ;; Create entry for face with background COLOR.
19129
35d85b50c3cb (cpp-create-bg-face): Don't really make a face.
Richard M. Stallman <rms@gnu.org>
parents: 19009
diff changeset
798 (cons color (cons 'background-color color)))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
799
30541
d5e4d3d5012c (toplevel): Support faces on tty's.
Eli Zaretskii <eliz@gnu.org>
parents: 28467
diff changeset
800 (cpp-choose-default-face
d5e4d3d5012c (toplevel): Support faces on tty's.
Eli Zaretskii <eliz@gnu.org>
parents: 28467
diff changeset
801 (if (or window-system (display-color-p)) cpp-face-type 'none))
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
802
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
803 (defun cpp-face-name (face)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
804 ;; Return the name of FACE from `cpp-face-all-list'.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
805 (let ((entry (rassq (if face face 'default) cpp-face-all-list)))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
806 (if entry
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
807 (car entry)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
808 (format "<%s>" face))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
809
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
810 ;;; Utilities:
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
811
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
812 (defvar cpp-progress-time 0)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
813 ;; Last time we issued a progress message.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
814
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
815 (defun cpp-progress-message (&rest args)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
816 ;; Report progress at most once a second. Take same ARGS as `message'.
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
817 (let ((time (nth 1 (current-time))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
818 (if (= time cpp-progress-time)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
819 ()
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
820 (setq cpp-progress-time time)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
821 (apply 'message args))))
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
822
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
823 (provide 'cpp)
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
824
52401
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 50986
diff changeset
825 ;;; arch-tag: fb7d433d-745d-495a-96f0-86908ab63f74
8735
d1f0811de024 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
826 ;;; cpp.el ends here