13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1 /* "Face" primitives.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
2 Copyright (C) 1993, 1994, 1995 Free Software Foundation.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
3
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
4 This file is part of GNU Emacs.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
5
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
6 GNU Emacs is free software; you can redistribute it and/or modify
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
7 it under the terms of the GNU General Public License as published by
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
8 the Free Software Foundation; either version 2, or (at your option)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
9 any later version.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
10
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
11 GNU Emacs is distributed in the hope that it will be useful,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
14 GNU General Public License for more details.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
15
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
16 You should have received a copy of the GNU General Public License
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
17 along with GNU Emacs; see the file COPYING. If not, write to
|
14186
|
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
19 Boston, MA 02111-1307, USA. */
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
20
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
21 /* Ported xfaces.c for win32 - Kevin Gallo */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
22
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
23 #include <sys/types.h>
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
24 #include <sys/stat.h>
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
25
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
26 #include <config.h>
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
27 #include "lisp.h"
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
28
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
29 #include "w32term.h"
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
30 #include "buffer.h"
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
31 #include "dispextern.h"
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
32 #include "frame.h"
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
33 #include "blockinput.h"
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
34 #include "window.h"
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
35 #include "intervals.h"
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
36
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
37
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
38 /* An explanation of the face data structures. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
39
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
40 /* ========================= Face Data Structures =========================
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
41
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
42 Let FACE-NAME be a symbol naming a face.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
43
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
44 Let FACE-VECTOR be (assq FACE-NAME (frame-face-alist FRAME))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
45 FACE-VECTOR is either nil, or a vector of the form
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
46 [face NAME ID FONT FOREGROUND BACKGROUND BACKGROUND-PIXMAP UNDERLINE-P]
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
47 where
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
48 face is the symbol `face',
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
49 NAME is the symbol with which this vector is associated (a backpointer),
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
50 ID is the face ID, an integer used internally by the C code to identify
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
51 the face,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
52 FONT, FOREGROUND, and BACKGROUND are strings naming the fonts and colors
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
53 to use with the face,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
54 BACKGROUND-PIXMAP is the name of an x bitmap filename, which we don't
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
55 use right now, and
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
56 UNDERLINE-P is non-nil if the face should be underlined.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
57 If any of these elements are nil, that parameter is considered
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
58 unspecified; parameters from faces specified by lower-priority
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
59 overlays or text properties, or the parameters of the frame itself,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
60 can show through. (lisp/faces.el maintains these lists.)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
61
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
62 (assq FACE-NAME global-face-data) returns a vector describing the
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
63 global parameters for that face.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
64
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
65 Let PARAM-FACE be FRAME->display.x->param_faces[Faref (FACE-VECTOR, 2)].
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
66 PARAM_FACE is a struct face whose members are the Xlib analogues of
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
67 the parameters in FACE-VECTOR. If an element of FACE-VECTOR is
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
68 nil, then the corresponding member of PARAM_FACE is FACE_DEFAULT.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
69 These faces are called "parameter faces", because they're the ones
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
70 lisp manipulates to control what gets displayed. Elements 0 and 1
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
71 of FRAME->display.x->param_faces are special - they describe the
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
72 default and mode line faces. None of the faces in param_faces have
|
14036
|
73 GC's. (See src/dispextern.h for the definition of struct face.
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
74 lisp/faces.el maintains the isomorphism between face_alist and
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
75 param_faces.)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
76
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
77 The functions compute_char_face and compute_glyph_face find and
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
78 combine the parameter faces associated with overlays and text
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
79 properties. The resulting faces are called "computed faces"; none
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
80 of their members are FACE_DEFAULT; they are completely specified.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
81 They then call intern_compute_face to search
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
82 FRAME->display.x->computed_faces for a matching face, add one if
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
83 none is found, and return the index into
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
84 FRAME->display.x->computed_faces. FRAME's glyph matrices use these
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
85 indices to record the faces of the matrix characters, and the X
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
86 display hooks consult compute_faces to decide how to display these
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
87 characters. Elements 0 and 1 of computed_faces always describe the
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
88 default and mode-line faces.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
89
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
90 Each computed face belongs to a particular frame.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
91
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
92 Computed faces have graphics contexts some of the time.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
93 intern_face builds a GC for a specified computed face
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
94 if it doesn't have one already.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
95 clear_face_cache clears out the GCs of all computed faces.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
96 This is done from time to time so that we don't hold on to
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
97 lots of GCs that are no longer needed.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
98
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
99 Constraints:
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
100
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
101 Symbols naming faces must have associations on all frames; for any
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
102 FRAME, for all FACE-NAME, if (assq FACE-NAME (frame-face-alist
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
103 FRAME)) is non-nil, it must be non-nil for all frames.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
104
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
105 Analogously, indices into param_faces must be valid on all frames;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
106 if param_faces[i] is a non-zero face pointer on one frame, then it
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
107 must be filled in on all frames. Code assumes that face ID's can
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
108 be used on any frame.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
109
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
110 Some subtleties:
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
111
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
112 Why do we keep param_faces and computed_faces separate?
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
113 computed_faces contains an element for every combination of facial
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
114 parameters we have ever displayed. indices into param_faces have
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
115 to be valid on all frames. If they were the same array, then that
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
116 array would grow very large on all frames, because any facial
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
117 combination displayed on any frame would need to be a valid entry
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
118 on all frames. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
119
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
120 /* Definitions and declarations. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
121
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
122 /* The number of face-id's in use (same for all frames). */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
123 static int next_face_id;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
124
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
125 /* The number of the face to use to indicate the region. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
126 static int region_face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
127
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
128 /* This is what appears in a slot in a face to signify that the face
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
129 does not specify that display aspect. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
130 #define FACE_DEFAULT (~0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
131
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
132 Lisp_Object Qface, Qmouse_face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
133 Lisp_Object Qpixmap_spec_p;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
134
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
135 int face_name_id_number ( /* FRAME_PTR, Lisp_Object name */ );
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
136
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
137 struct face *intern_face ( /* FRAME_PTR, struct face * */ );
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
138 static int new_computed_face ( /* FRAME_PTR, struct face * */ );
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
139 static int intern_computed_face ( /* FRAME_PTR, struct face * */ );
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
140 static void ensure_face_ready ( /* FRAME_PTR, int id */ );
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
141 void recompute_basic_faces ( /* FRAME_PTR f */ );
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
142
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
143 /* Allocating, copying, and comparing struct faces. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
144
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
145 /* Allocate a new face */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
146 static struct face *
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
147 allocate_face ()
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
148 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
149 struct face *result = (struct face *) xmalloc (sizeof (struct face));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
150 bzero (result, sizeof (struct face));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
151 result->font = (XFontStruct *) FACE_DEFAULT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
152 result->foreground = FACE_DEFAULT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
153 result->background = FACE_DEFAULT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
154 result->stipple = FACE_DEFAULT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
155 return result;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
156 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
157
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
158 /* Make a new face that's a copy of an existing one. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
159 static struct face *
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
160 copy_face (face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
161 struct face *face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
162 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
163 struct face *result = allocate_face ();
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
164
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
165 result->font = face->font;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
166 result->foreground = face->foreground;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
167 result->background = face->background;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
168 result->stipple = face->stipple;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
169 result->underline = face->underline;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
170 result->pixmap_h = face->pixmap_h;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
171 result->pixmap_w = face->pixmap_w;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
172
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
173 return result;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
174 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
175
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
176 static int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
177 face_eql (face1, face2)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
178 struct face *face1, *face2;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
179 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
180 return ( face1->font == face2->font
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
181 && face1->foreground == face2->foreground
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
182 && face1->background == face2->background
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
183 && face1->stipple == face2->stipple
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
184 && face1->underline == face2->underline);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
185 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
186
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
187 /* Managing graphics contexts of faces. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
188
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
189 /* Given a computed face, construct its graphics context if necessary. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
190
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
191 struct face *
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
192 intern_face (f, face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
193 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
194 struct face *face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
195 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
196 face->gc = NULL;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
197
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
198 return face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
199 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
200
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
201 /* Clear out all graphics contexts for all computed faces
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
202 except for the default and mode line faces.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
203 This should be done from time to time just to avoid
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
204 keeping too many graphics contexts that are no longer needed. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
205
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
206 void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
207 clear_face_cache ()
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
208 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
209 /* Nothing extra */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
210 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
211
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
212 /* Allocating, freeing, and duplicating fonts, colors, and pixmaps.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
213
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
214 These functions operate on param faces only.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
215 Computed faces get their fonts, colors and pixmaps
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
216 by merging param faces. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
217
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
218 static XFontStruct *
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
219 load_font (f, name)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
220 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
221 Lisp_Object name;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
222 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
223 XFontStruct *font;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
224
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
225 if (NILP (name))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
226 return (XFontStruct *) FACE_DEFAULT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
227
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
228 CHECK_STRING (name, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
229 BLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
230 font = win32_load_font (FRAME_WIN32_DISPLAY_INFO (f), (char *) XSTRING (name)->data);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
231 UNBLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
232
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
233 if (! font)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
234 Fsignal (Qerror, Fcons (build_string ("undefined font"),
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
235 Fcons (name, Qnil)));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
236 return font;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
237 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
238
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
239 static void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
240 unload_font (f, font)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
241 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
242 XFontStruct *font;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
243 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
244 if (!font || font == ((XFontStruct *) FACE_DEFAULT))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
245 return;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
246
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
247 BLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
248 win32_unload_font (FRAME_WIN32_DISPLAY_INFO (f), font);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
249 UNBLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
250 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
251
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
252 static unsigned long
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
253 load_color (f, name)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
254 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
255 Lisp_Object name;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
256 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
257 COLORREF color;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
258 int result;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
259
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
260 if (NILP (name))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
261 return FACE_DEFAULT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
262
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
263 CHECK_STRING (name, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
264 /* if the colormap is full, defined_color will return a best match
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
265 to the values in an an existing cell. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
266 result = defined_color(f, (char *) XSTRING (name)->data, &color, 1);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
267 if (! result)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
268 Fsignal (Qerror, Fcons (build_string ("undefined color"),
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
269 Fcons (name, Qnil)));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
270 return (unsigned long) color;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
271 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
272
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
273 static void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
274 unload_color (f, pixel)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
275 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
276 unsigned long pixel;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
277 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
278 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
279
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
280 DEFUN ("pixmap-spec-p", Fpixmap_spec_p, Spixmap_spec_p, 1, 1, 0,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
281 "Return t if ARG is a valid pixmap specification.")
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
282 (arg)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
283 Lisp_Object arg;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
284 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
285 Lisp_Object height, width;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
286
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
287 return ((STRINGP (arg)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
288 || (CONSP (arg)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
289 && CONSP (XCONS (arg)->cdr)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
290 && CONSP (XCONS (XCONS (arg)->cdr)->cdr)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
291 && NILP (XCONS (XCONS (XCONS (arg)->cdr)->cdr)->cdr)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
292 && (width = XCONS (arg)->car, INTEGERP (width))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
293 && (height = XCONS (XCONS (arg)->cdr)->car, INTEGERP (height))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
294 && STRINGP (XCONS (XCONS (XCONS (arg)->cdr)->cdr)->car)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
295 && XINT (width) > 0
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
296 && XINT (height) > 0
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
297 /* The string must have enough bits for width * height. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
298 && ((XSTRING (XCONS (XCONS (XCONS (arg)->cdr)->cdr)->car)->size
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
299 * (BITS_PER_INT / sizeof (int)))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
300 >= XFASTINT (width) * XFASTINT (height))))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
301 ? Qt : Qnil);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
302 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
303
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
304 /* Load a bitmap according to NAME (which is either a file name
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
305 or a pixmap spec). Return the bitmap_id (see xfns.c)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
306 or get an error if NAME is invalid.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
307
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
308 Store the bitmap width in *W_PTR and height in *H_PTR. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
309
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
310 static long
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
311 load_pixmap (f, name, w_ptr, h_ptr)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
312 FRAME_PTR f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
313 Lisp_Object name;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
314 unsigned int *w_ptr, *h_ptr;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
315 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
316 int bitmap_id;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
317 Lisp_Object tem;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
318
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
319 if (NILP (name))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
320 return FACE_DEFAULT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
321
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
322 tem = Fpixmap_spec_p (name);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
323 if (NILP (tem))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
324 wrong_type_argument (Qpixmap_spec_p, name);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
325
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
326 BLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
327
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
328 if (CONSP (name))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
329 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
330 /* Decode a bitmap spec into a bitmap. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
331
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
332 int h, w;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
333 Lisp_Object bits;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
334
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
335 w = XINT (Fcar (name));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
336 h = XINT (Fcar (Fcdr (name)));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
337 bits = Fcar (Fcdr (Fcdr (name)));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
338
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
339 bitmap_id = x_create_bitmap_from_data (f, XSTRING (bits)->data,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
340 w, h);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
341 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
342 else
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
343 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
344 /* It must be a string -- a file name. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
345 bitmap_id = x_create_bitmap_from_file (f, name);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
346 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
347 UNBLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
348
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
349 if (bitmap_id < 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
350 Fsignal (Qerror, Fcons (build_string ("invalid or undefined bitmap"),
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
351 Fcons (name, Qnil)));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
352
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
353 *w_ptr = x_bitmap_width (f, bitmap_id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
354 *h_ptr = x_bitmap_height (f, bitmap_id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
355
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
356 return bitmap_id;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
357 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
358
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
359
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
360 /* Managing parameter face arrays for frames. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
361
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
362 void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
363 init_frame_faces (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
364 FRAME_PTR f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
365 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
366 ensure_face_ready (f, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
367 ensure_face_ready (f, 1);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
368
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
369 FRAME_N_COMPUTED_FACES (f) = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
370 FRAME_SIZE_COMPUTED_FACES (f) = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
371
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
372 new_computed_face (f, FRAME_PARAM_FACES (f)[0]);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
373 new_computed_face (f, FRAME_PARAM_FACES (f)[1]);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
374 recompute_basic_faces (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
375
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
376 /* Find another frame. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
377 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
378 Lisp_Object tail, frame, result;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
379
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
380 result = Qnil;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
381 FOR_EACH_FRAME (tail, frame)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
382 if (FRAME_WIN32_P (XFRAME (frame))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
383 && XFRAME (frame) != f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
384 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
385 result = frame;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
386 break;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
387 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
388
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
389 /* If we didn't find any X frames other than f, then we don't need
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
390 any faces other than 0 and 1, so we're okay. Otherwise, make
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
391 sure that all faces valid on the selected frame are also valid
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
392 on this new frame. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
393 if (FRAMEP (result))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
394 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
395 int i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
396 int n_faces = FRAME_N_PARAM_FACES (XFRAME (result));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
397 struct face **faces = FRAME_PARAM_FACES (XFRAME (result));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
398
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
399 for (i = 2; i < n_faces; i++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
400 if (faces[i])
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
401 ensure_face_ready (f, i);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
402 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
403 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
404 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
405
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
406
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
407 /* Called from Fdelete_frame. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
408
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
409 void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
410 free_frame_faces (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
411 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
412 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
413 int i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
414
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
415 BLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
416
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
417 for (i = 0; i < FRAME_N_PARAM_FACES (f); i++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
418 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
419 struct face *face = FRAME_PARAM_FACES (f) [i];
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
420 if (face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
421 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
422 unload_font (f, face->font);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
423 unload_color (f, face->foreground);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
424 unload_color (f, face->background);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
425 x_destroy_bitmap (f, face->stipple);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
426 xfree (face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
427 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
428 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
429 xfree (FRAME_PARAM_FACES (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
430 FRAME_PARAM_FACES (f) = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
431 FRAME_N_PARAM_FACES (f) = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
432
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
433 /* All faces in FRAME_COMPUTED_FACES use resources copied from
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
434 FRAME_PARAM_FACES; we can free them without fuss.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
435 But we do free the GCs and the face objects themselves. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
436 for (i = 0; i < FRAME_N_COMPUTED_FACES (f); i++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
437 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
438 struct face *face = FRAME_COMPUTED_FACES (f) [i];
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
439 if (face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
440 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
441 xfree (face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
442 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
443 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
444 xfree (FRAME_COMPUTED_FACES (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
445 FRAME_COMPUTED_FACES (f) = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
446 FRAME_N_COMPUTED_FACES (f) = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
447
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
448 UNBLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
449 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
450
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
451 /* Interning faces in a frame's face array. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
452
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
453 static int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
454 new_computed_face (f, new_face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
455 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
456 struct face *new_face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
457 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
458 int i = FRAME_N_COMPUTED_FACES (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
459
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
460 if (i >= FRAME_SIZE_COMPUTED_FACES (f))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
461 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
462 int new_size = i + 32;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
463
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
464 FRAME_COMPUTED_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
465 = (struct face **) (FRAME_SIZE_COMPUTED_FACES (f) == 0
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
466 ? xmalloc (new_size * sizeof (struct face *))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
467 : xrealloc (FRAME_COMPUTED_FACES (f),
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
468 new_size * sizeof (struct face *)));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
469 FRAME_SIZE_COMPUTED_FACES (f) = new_size;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
470 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
471
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
472 i = FRAME_N_COMPUTED_FACES (f)++;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
473 FRAME_COMPUTED_FACES (f)[i] = copy_face (new_face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
474 return i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
475 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
476
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
477
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
478 /* Find a match for NEW_FACE in a FRAME's computed face array, and add
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
479 it if we don't find one. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
480 static int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
481 intern_computed_face (f, new_face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
482 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
483 struct face *new_face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
484 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
485 int len = FRAME_N_COMPUTED_FACES (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
486 int i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
487
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
488 /* Search for a computed face already on F equivalent to FACE. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
489 for (i = 0; i < len; i++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
490 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
491 if (! FRAME_COMPUTED_FACES (f)[i])
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
492 abort ();
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
493 if (face_eql (new_face, FRAME_COMPUTED_FACES (f)[i]))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
494 return i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
495 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
496
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
497 /* We didn't find one; add a new one. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
498 return new_computed_face (f, new_face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
499 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
500
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
501 /* Make parameter face id ID valid on frame F. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
502
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
503 static void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
504 ensure_face_ready (f, id)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
505 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
506 int id;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
507 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
508 if (FRAME_N_PARAM_FACES (f) <= id)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
509 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
510 int n = id + 10;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
511 int i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
512 if (!FRAME_N_PARAM_FACES (f))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
513 FRAME_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
514 = (struct face **) xmalloc (sizeof (struct face *) * n);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
515 else
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
516 FRAME_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
517 = (struct face **) xrealloc (FRAME_PARAM_FACES (f),
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
518 sizeof (struct face *) * n);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
519
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
520 bzero (FRAME_PARAM_FACES (f) + FRAME_N_PARAM_FACES (f),
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
521 (n - FRAME_N_PARAM_FACES (f)) * sizeof (struct face *));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
522 FRAME_N_PARAM_FACES (f) = n;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
523 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
524
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
525 if (FRAME_PARAM_FACES (f) [id] == 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
526 FRAME_PARAM_FACES (f) [id] = allocate_face ();
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
527 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
528
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
529 /* Return non-zero if FONT1 and FONT2 have the same width.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
530 We do not check the height, because we can now deal with
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
531 different heights.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
532 We assume that they're both character-cell fonts. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
533
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
534 int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
535 same_size_fonts (font1, font2)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
536 XFontStruct *font1, *font2;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
537 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
538 return (FONT_WIDTH(font1) == FONT_WIDTH(font2));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
539 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
540
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
541 /* Update the line_height of frame F according to the biggest font in
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
542 any face. Return nonzero if if line_height changes. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
543
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
544 int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
545 frame_update_line_height (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
546 FRAME_PTR f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
547 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
548 int i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
549 int biggest = FONT_HEIGHT (f->output_data.win32->font);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
550
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
551 for (i = 0; i < f->output_data.win32->n_param_faces; i++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
552 if (f->output_data.win32->param_faces[i] != 0
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
553 && f->output_data.win32->param_faces[i]->font != (XFontStruct *) FACE_DEFAULT)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
554 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
555 int height = FONT_HEIGHT (f->output_data.win32->param_faces[i]->font);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
556 if (height > biggest)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
557 biggest = height;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
558 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
559
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
560 if (biggest == f->output_data.win32->line_height)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
561 return 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
562
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
563 f->output_data.win32->line_height = biggest;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
564 return 1;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
565 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
566
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
567 /* Modify face TO by copying from FROM all properties which have
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
568 nondefault settings. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
569
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
570 static void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
571 merge_faces (from, to)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
572 struct face *from, *to;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
573 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
574 /* Only merge the font if it's the same width as the base font.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
575 Otherwise ignore it, since we can't handle it properly. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
576 if (from->font != (XFontStruct *) FACE_DEFAULT
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
577 && same_size_fonts (from->font, to->font))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
578 to->font = from->font;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
579 if (from->foreground != FACE_DEFAULT)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
580 to->foreground = from->foreground;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
581 if (from->background != FACE_DEFAULT)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
582 to->background = from->background;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
583 if (from->stipple != FACE_DEFAULT)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
584 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
585 to->stipple = from->stipple;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
586 to->pixmap_h = from->pixmap_h;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
587 to->pixmap_w = from->pixmap_w;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
588 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
589 if (from->underline)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
590 to->underline = from->underline;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
591 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
592
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
593 /* Set up the basic set of facial parameters, based on the frame's
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
594 data; all faces are deltas applied to this. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
595
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
596 static void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
597 compute_base_face (f, face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
598 FRAME_PTR f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
599 struct face *face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
600 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
601 face->gc = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
602 face->foreground = FRAME_FOREGROUND_PIXEL (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
603 face->background = FRAME_BACKGROUND_PIXEL (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
604 face->font = FRAME_FONT (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
605 face->stipple = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
606 face->underline = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
607 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
608
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
609 /* Return the face ID to use to display a special glyph which selects
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
610 FACE_CODE as the face ID, assuming that ordinarily the face would
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
611 be CURRENT_FACE. F is the frame. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
612
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
613 int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
614 compute_glyph_face (f, face_code, current_face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
615 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
616 int face_code, current_face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
617 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
618 struct face face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
619
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
620 face = *FRAME_COMPUTED_FACES (f)[current_face];
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
621
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
622 if (face_code >= 0 && face_code < FRAME_N_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
623 && FRAME_PARAM_FACES (f) [face_code] != 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
624 merge_faces (FRAME_PARAM_FACES (f) [face_code], &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
625
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
626 return intern_computed_face (f, &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
627 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
628
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
629 /* Return the face ID to use to display a special glyph which selects
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
630 FACE_CODE as the face ID, assuming that ordinarily the face would
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
631 be CURRENT_FACE. F is the frame. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
632
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
633 int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
634 compute_glyph_face_1 (f, face_name, current_face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
635 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
636 Lisp_Object face_name;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
637 int current_face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
638 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
639 struct face face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
640
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
641 face = *FRAME_COMPUTED_FACES (f)[current_face];
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
642
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
643 if (!NILP (face_name))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
644 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
645 int facecode = face_name_id_number (f, face_name);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
646 if (facecode >= 0 && facecode < FRAME_N_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
647 && FRAME_PARAM_FACES (f) [facecode] != 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
648 merge_faces (FRAME_PARAM_FACES (f) [facecode], &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
649 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
650
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
651 return intern_computed_face (f, &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
652 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
653
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
654 /* Return the face ID associated with a buffer position POS.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
655 Store into *ENDPTR the position at which a different face is needed.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
656 This does not take account of glyphs that specify their own face codes.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
657 F is the frame in use for display, and W is a window displaying
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
658 the current buffer.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
659
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
660 REGION_BEG, REGION_END delimit the region, so it can be highlighted.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
661
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
662 LIMIT is a position not to scan beyond. That is to limit
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
663 the time this function can take.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
664
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
665 If MOUSE is nonzero, use the character's mouse-face, not its face. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
666
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
667 int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
668 compute_char_face (f, w, pos, region_beg, region_end, endptr, limit, mouse)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
669 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
670 struct window *w;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
671 int pos;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
672 int region_beg, region_end;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
673 int *endptr;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
674 int limit;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
675 int mouse;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
676 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
677 struct face face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
678 Lisp_Object prop, position;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
679 int i, j, noverlays;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
680 int facecode;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
681 Lisp_Object *overlay_vec;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
682 Lisp_Object frame;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
683 int endpos;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
684 Lisp_Object propname;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
685
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
686 /* W must display the current buffer. We could write this function
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
687 to use the frame and buffer of W, but right now it doesn't. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
688 if (XBUFFER (w->buffer) != current_buffer)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
689 abort ();
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
690
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
691 XSETFRAME (frame, f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
692
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
693 endpos = ZV;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
694 if (pos < region_beg && region_beg < endpos)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
695 endpos = region_beg;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
696
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
697 XSETFASTINT (position, pos);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
698
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
699 if (mouse)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
700 propname = Qmouse_face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
701 else
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
702 propname = Qface;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
703
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
704 prop = Fget_text_property (position, propname, w->buffer);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
705
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
706 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
707 Lisp_Object limit1, end;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
708
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
709 XSETFASTINT (limit1, (limit < endpos ? limit : endpos));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
710 end = Fnext_single_property_change (position, propname, w->buffer, limit1);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
711 if (INTEGERP (end))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
712 endpos = XINT (end);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
713 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
714
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
715 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
716 int next_overlay;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
717 int len;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
718
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
719 /* First try with room for 40 overlays. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
720 len = 40;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
721 overlay_vec = (Lisp_Object *) alloca (len * sizeof (Lisp_Object));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
722
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
723 noverlays = overlays_at (pos, 0, &overlay_vec, &len,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
724 &next_overlay, (int *) 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
725
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
726 /* If there are more than 40,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
727 make enough space for all, and try again. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
728 if (noverlays > len)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
729 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
730 len = noverlays;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
731 overlay_vec = (Lisp_Object *) alloca (len * sizeof (Lisp_Object));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
732 noverlays = overlays_at (pos, 0, &overlay_vec, &len,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
733 &next_overlay, (int *) 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
734 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
735
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
736 if (next_overlay < endpos)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
737 endpos = next_overlay;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
738 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
739
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
740 *endptr = endpos;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
741
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
742 /* Optimize the default case. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
743 if (noverlays == 0 && NILP (prop)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
744 && !(pos >= region_beg && pos < region_end))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
745 return 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
746
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
747 compute_base_face (f, &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
748
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
749 if (CONSP (prop))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
750 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
751 /* We have a list of faces, merge them in reverse order */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
752 Lisp_Object length = Flength (prop);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
753 int len = XINT (length);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
754 Lisp_Object *faces;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
755
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
756 /* Put them into an array */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
757 faces = (Lisp_Object *) alloca (len * sizeof (Lisp_Object));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
758 for (j = 0; j < len; j++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
759 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
760 faces[j] = Fcar (prop);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
761 prop = Fcdr (prop);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
762 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
763 /* So that we can merge them in the reverse order */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
764 for (j = len - 1; j >= 0; j--)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
765 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
766 facecode = face_name_id_number (f, faces[j]);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
767 if (facecode >= 0 && facecode < FRAME_N_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
768 && FRAME_PARAM_FACES (f) [facecode] != 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
769 merge_faces (FRAME_PARAM_FACES (f) [facecode], &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
770 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
771 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
772 else if (!NILP (prop))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
773 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
774 facecode = face_name_id_number (f, prop);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
775 if (facecode >= 0 && facecode < FRAME_N_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
776 && FRAME_PARAM_FACES (f) [facecode] != 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
777 merge_faces (FRAME_PARAM_FACES (f) [facecode], &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
778 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
779
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
780 noverlays = sort_overlays (overlay_vec, noverlays, w);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
781
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
782 /* Now merge the overlay data in that order. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
783 for (i = 0; i < noverlays; i++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
784 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
785 prop = Foverlay_get (overlay_vec[i], propname);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
786 if (CONSP (prop))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
787 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
788 /* We have a list of faces, merge them in reverse order */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
789 Lisp_Object length = Flength (prop);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
790 int len = XINT (length);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
791 Lisp_Object *faces;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
792 int i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
793
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
794 /* Put them into an array */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
795 faces = (Lisp_Object *) alloca (len * sizeof (Lisp_Object));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
796 for (j = 0; j < len; j++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
797 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
798 faces[j] = Fcar (prop);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
799 prop = Fcdr (prop);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
800 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
801 /* So that we can merge them in the reverse order */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
802 for (j = len - 1; j >= 0; j--)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
803 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
804 facecode = face_name_id_number (f, faces[j]);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
805 if (facecode >= 0 && facecode < FRAME_N_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
806 && FRAME_PARAM_FACES (f) [facecode] != 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
807 merge_faces (FRAME_PARAM_FACES (f) [facecode], &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
808 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
809 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
810 else if (!NILP (prop))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
811 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
812 Lisp_Object oend;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
813 int oendpos;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
814
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
815 facecode = face_name_id_number (f, prop);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
816 if (facecode >= 0 && facecode < FRAME_N_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
817 && FRAME_PARAM_FACES (f) [facecode] != 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
818 merge_faces (FRAME_PARAM_FACES (f)[facecode], &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
819
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
820 oend = OVERLAY_END (overlay_vec[i]);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
821 oendpos = OVERLAY_POSITION (oend);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
822 if (oendpos < endpos)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
823 endpos = oendpos;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
824 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
825 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
826
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
827 if (pos >= region_beg && pos < region_end)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
828 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
829 if (region_end < endpos)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
830 endpos = region_end;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
831 if (region_face >= 0 && region_face < next_face_id)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
832 merge_faces (FRAME_PARAM_FACES (f)[region_face], &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
833 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
834
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
835 *endptr = endpos;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
836
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
837 return intern_computed_face (f, &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
838 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
839
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
840 /* Recompute the GC's for the default and modeline faces.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
841 We call this after changing frame parameters on which those GC's
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
842 depend. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
843
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
844 void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
845 recompute_basic_faces (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
846 FRAME_PTR f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
847 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
848 /* If the frame's faces haven't been initialized yet, don't worry about
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
849 this stuff. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
850 if (FRAME_N_PARAM_FACES (f) < 2)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
851 return;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
852
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
853 BLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
854
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
855 compute_base_face (f, FRAME_DEFAULT_FACE (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
856 compute_base_face (f, FRAME_MODE_LINE_FACE (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
857
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
858 merge_faces (FRAME_DEFAULT_PARAM_FACE (f), FRAME_DEFAULT_FACE (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
859 merge_faces (FRAME_MODE_LINE_PARAM_FACE (f), FRAME_MODE_LINE_FACE (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
860
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
861 intern_face (f, FRAME_DEFAULT_FACE (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
862 intern_face (f, FRAME_MODE_LINE_FACE (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
863
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
864 UNBLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
865 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
866
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
867
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
868
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
869 /* Lisp interface. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
870
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
871 DEFUN ("frame-face-alist", Fframe_face_alist, Sframe_face_alist, 1, 1, 0,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
872 "")
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
873 (frame)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
874 Lisp_Object frame;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
875 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
876 CHECK_FRAME (frame, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
877 return XFRAME (frame)->face_alist;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
878 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
879
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
880 DEFUN ("set-frame-face-alist", Fset_frame_face_alist, Sset_frame_face_alist,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
881 2, 2, 0, "")
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
882 (frame, value)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
883 Lisp_Object frame, value;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
884 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
885 CHECK_FRAME (frame, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
886 XFRAME (frame)->face_alist = value;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
887 return value;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
888 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
889
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
890
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
891 DEFUN ("make-face-internal", Fmake_face_internal, Smake_face_internal, 1, 1, 0,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
892 "Create face number FACE-ID on all frames.")
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
893 (face_id)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
894 Lisp_Object face_id;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
895 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
896 Lisp_Object rest, frame;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
897 int id = XINT (face_id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
898
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
899 CHECK_NUMBER (face_id, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
900 if (id < 0 || id >= next_face_id)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
901 error ("Face id out of range");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
902
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
903 FOR_EACH_FRAME (rest, frame)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
904 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
905 if (FRAME_WIN32_P (XFRAME (frame)))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
906 ensure_face_ready (XFRAME (frame), id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
907 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
908 return Qnil;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
909 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
910
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
911
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
912 DEFUN ("set-face-attribute-internal", Fset_face_attribute_internal,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
913 Sset_face_attribute_internal, 4, 4, 0, "")
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
914 (face_id, attr_name, attr_value, frame)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
915 Lisp_Object face_id, attr_name, attr_value, frame;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
916 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
917 struct face *face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
918 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
919 int magic_p;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
920 int id;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
921 int garbaged = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
922
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
923 CHECK_FRAME (frame, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
924 CHECK_NUMBER (face_id, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
925 CHECK_SYMBOL (attr_name, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
926
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
927 f = XFRAME (frame);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
928 id = XINT (face_id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
929 if (id < 0 || id >= next_face_id)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
930 error ("Face id out of range");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
931
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
932 if (! FRAME_WIN32_P (f))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
933 return Qnil;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
934
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
935 ensure_face_ready (f, id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
936 face = FRAME_PARAM_FACES (f) [XFASTINT (face_id)];
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
937
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
938 if (EQ (attr_name, intern ("font")))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
939 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
940 XFontStruct *font = load_font (f, attr_value);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
941 if (face->font != f->output_data.win32->font)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
942 unload_font (f, face->font);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
943 face->font = font;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
944 if (frame_update_line_height (f))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
945 x_set_window_size (f, 0, f->width, f->height);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
946 /* Must clear cache, since it might contain the font
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
947 we just got rid of. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
948 garbaged = 1;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
949 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
950 else if (EQ (attr_name, intern ("foreground")))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
951 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
952 unsigned long new_color = load_color (f, attr_value);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
953 unload_color (f, face->foreground);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
954 face->foreground = new_color;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
955 garbaged = 1;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
956 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
957 else if (EQ (attr_name, intern ("background")))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
958 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
959 unsigned long new_color = load_color (f, attr_value);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
960 unload_color (f, face->background);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
961 face->background = new_color;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
962 garbaged = 1;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
963 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
964 else if (EQ (attr_name, intern ("background-pixmap")))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
965 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
966 unsigned int w, h;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
967 unsigned long new_pixmap = load_pixmap (f, attr_value, &w, &h);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
968 x_destroy_bitmap (f, face->stipple);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
969 face->stipple = (Pixmap) new_pixmap;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
970 face->pixmap_w = w;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
971 face->pixmap_h = h;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
972 garbaged = 1;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
973 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
974 else if (EQ (attr_name, intern ("underline")))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
975 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
976 int new = !NILP (attr_value);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
977 face->underline = new;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
978 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
979 else
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
980 error ("unknown face attribute");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
981
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
982 if (id == 0 || id == 1)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
983 recompute_basic_faces (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
984
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
985 /* We must redraw the frame whenever any face font or color changes,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
986 because it's possible that a merged (display) face
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
987 contains the font or color we just replaced.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
988 And we must inhibit any Expose events until the redraw is done,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
989 since they would try to use the invalid display faces. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
990 if (garbaged)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
991 SET_FRAME_GARBAGED (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
992
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
993 return Qnil;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
994 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
995
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
996 DEFUN ("internal-next-face-id", Finternal_next_face_id, Sinternal_next_face_id,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
997 0, 0, 0, "")
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
998 ()
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
999 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1000 return make_number (next_face_id++);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1001 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1002
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1003 /* Return the face id for name NAME on frame FRAME.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1004 (It should be the same for all frames,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1005 but it's as easy to use the "right" frame to look it up
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1006 as to use any other one.) */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1007
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1008 int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1009 face_name_id_number (f, name)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1010 FRAME_PTR f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1011 Lisp_Object name;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1012 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1013 Lisp_Object tem;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1014
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1015 tem = Fcdr (assq_no_quit (name, f->face_alist));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1016 if (NILP (tem))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1017 return 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1018 CHECK_VECTOR (tem, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1019 tem = XVECTOR (tem)->contents[2];
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1020 CHECK_NUMBER (tem, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1021 return XINT (tem);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1022 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1023
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1024 /* Emacs initialization. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1025
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1026 void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1027 syms_of_win32faces ()
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1028 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1029 Qface = intern ("face");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1030 staticpro (&Qface);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1031 Qmouse_face = intern ("mouse-face");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1032 staticpro (&Qmouse_face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1033 Qpixmap_spec_p = intern ("pixmap-spec-p");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1034 staticpro (&Qpixmap_spec_p);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1035
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1036 DEFVAR_INT ("region-face", ®ion_face,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1037 "Face number to use to highlight the region\n\
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1038 The region is highlighted with this face\n\
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1039 when Transient Mark mode is enabled and the mark is active.");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1040
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1041 defsubr (&Spixmap_spec_p);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1042 defsubr (&Sframe_face_alist);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1043 defsubr (&Sset_frame_face_alist);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1044 defsubr (&Smake_face_internal);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1045 defsubr (&Sset_face_attribute_internal);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1046 defsubr (&Sinternal_next_face_id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1047 }
|