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 #ifdef MULTI_FRAME
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
377 /* Find another frame. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
378 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
379 Lisp_Object tail, frame, result;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
380
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
381 result = Qnil;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
382 FOR_EACH_FRAME (tail, frame)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
383 if (FRAME_WIN32_P (XFRAME (frame))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
384 && XFRAME (frame) != f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
385 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
386 result = frame;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
387 break;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
388 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
389
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
390 /* 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
|
391 any faces other than 0 and 1, so we're okay. Otherwise, make
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
392 sure that all faces valid on the selected frame are also valid
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
393 on this new frame. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
394 if (FRAMEP (result))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
395 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
396 int i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
397 int n_faces = FRAME_N_PARAM_FACES (XFRAME (result));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
398 struct face **faces = FRAME_PARAM_FACES (XFRAME (result));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
399
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
400 for (i = 2; i < n_faces; i++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
401 if (faces[i])
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
402 ensure_face_ready (f, i);
|
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 #endif /* MULTI_FRAME */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
406 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
407
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
408
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
409 /* Called from Fdelete_frame. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
410
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
411 void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
412 free_frame_faces (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
413 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
414 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
415 int i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
416
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
417 BLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
418
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
419 for (i = 0; i < FRAME_N_PARAM_FACES (f); i++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
420 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
421 struct face *face = FRAME_PARAM_FACES (f) [i];
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
422 if (face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
423 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
424 unload_font (f, face->font);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
425 unload_color (f, face->foreground);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
426 unload_color (f, face->background);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
427 x_destroy_bitmap (f, face->stipple);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
428 xfree (face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
429 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
430 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
431 xfree (FRAME_PARAM_FACES (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
432 FRAME_PARAM_FACES (f) = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
433 FRAME_N_PARAM_FACES (f) = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
434
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
435 /* All faces in FRAME_COMPUTED_FACES use resources copied from
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
436 FRAME_PARAM_FACES; we can free them without fuss.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
437 But we do free the GCs and the face objects themselves. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
438 for (i = 0; i < FRAME_N_COMPUTED_FACES (f); i++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
439 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
440 struct face *face = FRAME_COMPUTED_FACES (f) [i];
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
441 if (face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
442 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
443 xfree (face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
444 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
445 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
446 xfree (FRAME_COMPUTED_FACES (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
447 FRAME_COMPUTED_FACES (f) = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
448 FRAME_N_COMPUTED_FACES (f) = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
449
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
450 UNBLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
451 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
452
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
453 /* Interning faces in a frame's face array. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
454
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
455 static int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
456 new_computed_face (f, new_face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
457 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
458 struct face *new_face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
459 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
460 int i = FRAME_N_COMPUTED_FACES (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
461
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
462 if (i >= FRAME_SIZE_COMPUTED_FACES (f))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
463 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
464 int new_size = i + 32;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
465
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
466 FRAME_COMPUTED_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
467 = (struct face **) (FRAME_SIZE_COMPUTED_FACES (f) == 0
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
468 ? xmalloc (new_size * sizeof (struct face *))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
469 : xrealloc (FRAME_COMPUTED_FACES (f),
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
470 new_size * sizeof (struct face *)));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
471 FRAME_SIZE_COMPUTED_FACES (f) = new_size;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
472 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
473
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
474 i = FRAME_N_COMPUTED_FACES (f)++;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
475 FRAME_COMPUTED_FACES (f)[i] = copy_face (new_face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
476 return i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
477 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
478
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
479
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
480 /* Find a match for NEW_FACE in a FRAME's computed face array, and add
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
481 it if we don't find one. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
482 static int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
483 intern_computed_face (f, new_face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
484 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
485 struct face *new_face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
486 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
487 int len = FRAME_N_COMPUTED_FACES (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
488 int i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
489
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
490 /* Search for a computed face already on F equivalent to FACE. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
491 for (i = 0; i < len; i++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
492 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
493 if (! FRAME_COMPUTED_FACES (f)[i])
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
494 abort ();
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
495 if (face_eql (new_face, FRAME_COMPUTED_FACES (f)[i]))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
496 return i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
497 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
498
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
499 /* We didn't find one; add a new one. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
500 return new_computed_face (f, new_face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
501 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
502
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
503 /* Make parameter face id ID valid on frame F. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
504
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
505 static void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
506 ensure_face_ready (f, id)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
507 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
508 int id;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
509 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
510 if (FRAME_N_PARAM_FACES (f) <= id)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
511 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
512 int n = id + 10;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
513 int i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
514 if (!FRAME_N_PARAM_FACES (f))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
515 FRAME_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
516 = (struct face **) xmalloc (sizeof (struct face *) * n);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
517 else
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
518 FRAME_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
519 = (struct face **) xrealloc (FRAME_PARAM_FACES (f),
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
520 sizeof (struct face *) * n);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
521
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
522 bzero (FRAME_PARAM_FACES (f) + FRAME_N_PARAM_FACES (f),
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
523 (n - FRAME_N_PARAM_FACES (f)) * sizeof (struct face *));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
524 FRAME_N_PARAM_FACES (f) = n;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
525 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
526
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
527 if (FRAME_PARAM_FACES (f) [id] == 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
528 FRAME_PARAM_FACES (f) [id] = allocate_face ();
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
529 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
530
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
531 /* Return non-zero if FONT1 and FONT2 have the same width.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
532 We do not check the height, because we can now deal with
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
533 different heights.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
534 We assume that they're both character-cell fonts. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
535
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
536 int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
537 same_size_fonts (font1, font2)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
538 XFontStruct *font1, *font2;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
539 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
540 return (FONT_WIDTH(font1) == FONT_WIDTH(font2));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
541 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
542
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
543 /* Update the line_height of frame F according to the biggest font in
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
544 any face. Return nonzero if if line_height changes. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
545
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
546 int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
547 frame_update_line_height (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
548 FRAME_PTR f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
549 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
550 int i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
551 int biggest = FONT_HEIGHT (f->output_data.win32->font);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
552
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
553 for (i = 0; i < f->output_data.win32->n_param_faces; i++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
554 if (f->output_data.win32->param_faces[i] != 0
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
555 && f->output_data.win32->param_faces[i]->font != (XFontStruct *) FACE_DEFAULT)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
556 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
557 int height = FONT_HEIGHT (f->output_data.win32->param_faces[i]->font);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
558 if (height > biggest)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
559 biggest = height;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
560 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
561
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
562 if (biggest == f->output_data.win32->line_height)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
563 return 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
564
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
565 f->output_data.win32->line_height = biggest;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
566 return 1;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
567 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
568
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
569 /* Modify face TO by copying from FROM all properties which have
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
570 nondefault settings. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
571
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
572 static void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
573 merge_faces (from, to)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
574 struct face *from, *to;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
575 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
576 /* Only merge the font if it's the same width as the base font.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
577 Otherwise ignore it, since we can't handle it properly. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
578 if (from->font != (XFontStruct *) FACE_DEFAULT
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
579 && same_size_fonts (from->font, to->font))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
580 to->font = from->font;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
581 if (from->foreground != FACE_DEFAULT)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
582 to->foreground = from->foreground;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
583 if (from->background != FACE_DEFAULT)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
584 to->background = from->background;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
585 if (from->stipple != FACE_DEFAULT)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
586 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
587 to->stipple = from->stipple;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
588 to->pixmap_h = from->pixmap_h;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
589 to->pixmap_w = from->pixmap_w;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
590 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
591 if (from->underline)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
592 to->underline = from->underline;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
593 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
594
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
595 /* Set up the basic set of facial parameters, based on the frame's
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
596 data; all faces are deltas applied to this. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
597
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
598 static void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
599 compute_base_face (f, face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
600 FRAME_PTR f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
601 struct face *face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
602 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
603 face->gc = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
604 face->foreground = FRAME_FOREGROUND_PIXEL (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
605 face->background = FRAME_BACKGROUND_PIXEL (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
606 face->font = FRAME_FONT (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
607 face->stipple = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
608 face->underline = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
609 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
610
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
611 /* Return the face ID to use to display a special glyph which selects
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
612 FACE_CODE as the face ID, assuming that ordinarily the face would
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
613 be CURRENT_FACE. F is the frame. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
614
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
615 int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
616 compute_glyph_face (f, face_code, current_face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
617 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
618 int face_code, current_face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
619 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
620 struct face face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
621
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
622 face = *FRAME_COMPUTED_FACES (f)[current_face];
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
623
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
624 if (face_code >= 0 && face_code < FRAME_N_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
625 && FRAME_PARAM_FACES (f) [face_code] != 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
626 merge_faces (FRAME_PARAM_FACES (f) [face_code], &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
627
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
628 return intern_computed_face (f, &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
629 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
630
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
631 /* Return the face ID to use to display a special glyph which selects
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
632 FACE_CODE as the face ID, assuming that ordinarily the face would
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
633 be CURRENT_FACE. F is the frame. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
634
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
635 int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
636 compute_glyph_face_1 (f, face_name, current_face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
637 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
638 Lisp_Object face_name;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
639 int current_face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
640 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
641 struct face face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
642
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
643 face = *FRAME_COMPUTED_FACES (f)[current_face];
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
644
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
645 if (!NILP (face_name))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
646 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
647 int facecode = face_name_id_number (f, face_name);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
648 if (facecode >= 0 && facecode < FRAME_N_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
649 && FRAME_PARAM_FACES (f) [facecode] != 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
650 merge_faces (FRAME_PARAM_FACES (f) [facecode], &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
651 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
652
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
653 return intern_computed_face (f, &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
654 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
655
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
656 /* Return the face ID associated with a buffer position POS.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
657 Store into *ENDPTR the position at which a different face is needed.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
658 This does not take account of glyphs that specify their own face codes.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
659 F is the frame in use for display, and W is a window displaying
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
660 the current buffer.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
661
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
662 REGION_BEG, REGION_END delimit the region, so it can be highlighted.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
663
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
664 LIMIT is a position not to scan beyond. That is to limit
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
665 the time this function can take.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
666
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
667 If MOUSE is nonzero, use the character's mouse-face, not its face. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
668
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
669 int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
670 compute_char_face (f, w, pos, region_beg, region_end, endptr, limit, mouse)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
671 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
672 struct window *w;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
673 int pos;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
674 int region_beg, region_end;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
675 int *endptr;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
676 int limit;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
677 int mouse;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
678 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
679 struct face face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
680 Lisp_Object prop, position;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
681 int i, j, noverlays;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
682 int facecode;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
683 Lisp_Object *overlay_vec;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
684 Lisp_Object frame;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
685 int endpos;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
686 Lisp_Object propname;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
687
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
688 /* W must display the current buffer. We could write this function
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
689 to use the frame and buffer of W, but right now it doesn't. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
690 if (XBUFFER (w->buffer) != current_buffer)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
691 abort ();
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
692
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
693 XSETFRAME (frame, f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
694
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
695 endpos = ZV;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
696 if (pos < region_beg && region_beg < endpos)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
697 endpos = region_beg;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
698
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
699 XSETFASTINT (position, pos);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
700
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
701 if (mouse)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
702 propname = Qmouse_face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
703 else
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
704 propname = Qface;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
705
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
706 prop = Fget_text_property (position, propname, w->buffer);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
707
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
708 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
709 Lisp_Object limit1, end;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
710
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
711 XSETFASTINT (limit1, (limit < endpos ? limit : endpos));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
712 end = Fnext_single_property_change (position, propname, w->buffer, limit1);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
713 if (INTEGERP (end))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
714 endpos = XINT (end);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
715 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
716
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
717 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
718 int next_overlay;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
719 int len;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
720
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
721 /* First try with room for 40 overlays. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
722 len = 40;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
723 overlay_vec = (Lisp_Object *) alloca (len * sizeof (Lisp_Object));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
724
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
725 noverlays = overlays_at (pos, 0, &overlay_vec, &len,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
726 &next_overlay, (int *) 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
727
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
728 /* If there are more than 40,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
729 make enough space for all, and try again. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
730 if (noverlays > len)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
731 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
732 len = noverlays;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
733 overlay_vec = (Lisp_Object *) alloca (len * sizeof (Lisp_Object));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
734 noverlays = overlays_at (pos, 0, &overlay_vec, &len,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
735 &next_overlay, (int *) 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
736 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
737
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
738 if (next_overlay < endpos)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
739 endpos = next_overlay;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
740 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
741
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
742 *endptr = endpos;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
743
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
744 /* Optimize the default case. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
745 if (noverlays == 0 && NILP (prop)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
746 && !(pos >= region_beg && pos < region_end))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
747 return 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
748
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
749 compute_base_face (f, &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
750
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
751 if (CONSP (prop))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
752 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
753 /* We have a list of faces, merge them in reverse order */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
754 Lisp_Object length = Flength (prop);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
755 int len = XINT (length);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
756 Lisp_Object *faces;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
757
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
758 /* Put them into an array */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
759 faces = (Lisp_Object *) alloca (len * sizeof (Lisp_Object));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
760 for (j = 0; j < len; j++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
761 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
762 faces[j] = Fcar (prop);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
763 prop = Fcdr (prop);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
764 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
765 /* So that we can merge them in the reverse order */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
766 for (j = len - 1; j >= 0; j--)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
767 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
768 facecode = face_name_id_number (f, faces[j]);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
769 if (facecode >= 0 && facecode < FRAME_N_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
770 && FRAME_PARAM_FACES (f) [facecode] != 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
771 merge_faces (FRAME_PARAM_FACES (f) [facecode], &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
772 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
773 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
774 else if (!NILP (prop))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
775 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
776 facecode = face_name_id_number (f, prop);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
777 if (facecode >= 0 && facecode < FRAME_N_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
778 && FRAME_PARAM_FACES (f) [facecode] != 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
779 merge_faces (FRAME_PARAM_FACES (f) [facecode], &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
780 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
781
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
782 noverlays = sort_overlays (overlay_vec, noverlays, w);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
783
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
784 /* Now merge the overlay data in that order. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
785 for (i = 0; i < noverlays; i++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
786 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
787 prop = Foverlay_get (overlay_vec[i], propname);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
788 if (CONSP (prop))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
789 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
790 /* We have a list of faces, merge them in reverse order */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
791 Lisp_Object length = Flength (prop);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
792 int len = XINT (length);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
793 Lisp_Object *faces;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
794 int i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
795
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
796 /* Put them into an array */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
797 faces = (Lisp_Object *) alloca (len * sizeof (Lisp_Object));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
798 for (j = 0; j < len; j++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
799 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
800 faces[j] = Fcar (prop);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
801 prop = Fcdr (prop);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
802 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
803 /* So that we can merge them in the reverse order */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
804 for (j = len - 1; j >= 0; j--)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
805 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
806 facecode = face_name_id_number (f, faces[j]);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
807 if (facecode >= 0 && facecode < FRAME_N_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
808 && FRAME_PARAM_FACES (f) [facecode] != 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
809 merge_faces (FRAME_PARAM_FACES (f) [facecode], &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
810 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
811 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
812 else if (!NILP (prop))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
813 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
814 Lisp_Object oend;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
815 int oendpos;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
816
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
817 facecode = face_name_id_number (f, prop);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
818 if (facecode >= 0 && facecode < FRAME_N_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
819 && FRAME_PARAM_FACES (f) [facecode] != 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
820 merge_faces (FRAME_PARAM_FACES (f)[facecode], &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
821
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
822 oend = OVERLAY_END (overlay_vec[i]);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
823 oendpos = OVERLAY_POSITION (oend);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
824 if (oendpos < endpos)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
825 endpos = oendpos;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
826 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
827 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
828
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
829 if (pos >= region_beg && pos < region_end)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
830 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
831 if (region_end < endpos)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
832 endpos = region_end;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
833 if (region_face >= 0 && region_face < next_face_id)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
834 merge_faces (FRAME_PARAM_FACES (f)[region_face], &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
835 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
836
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
837 *endptr = endpos;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
838
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
839 return intern_computed_face (f, &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
840 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
841
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
842 /* Recompute the GC's for the default and modeline faces.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
843 We call this after changing frame parameters on which those GC's
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
844 depend. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
845
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
846 void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
847 recompute_basic_faces (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
848 FRAME_PTR f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
849 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
850 /* If the frame's faces haven't been initialized yet, don't worry about
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
851 this stuff. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
852 if (FRAME_N_PARAM_FACES (f) < 2)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
853 return;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
854
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
855 BLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
856
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
857 compute_base_face (f, FRAME_DEFAULT_FACE (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
858 compute_base_face (f, FRAME_MODE_LINE_FACE (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
859
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
860 merge_faces (FRAME_DEFAULT_PARAM_FACE (f), FRAME_DEFAULT_FACE (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
861 merge_faces (FRAME_MODE_LINE_PARAM_FACE (f), FRAME_MODE_LINE_FACE (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
862
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
863 intern_face (f, FRAME_DEFAULT_FACE (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
864 intern_face (f, FRAME_MODE_LINE_FACE (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
865
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
866 UNBLOCK_INPUT;
|
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
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
870
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
871 /* Lisp interface. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
872
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
873 DEFUN ("frame-face-alist", Fframe_face_alist, Sframe_face_alist, 1, 1, 0,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
874 "")
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
875 (frame)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
876 Lisp_Object frame;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
877 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
878 CHECK_FRAME (frame, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
879 return XFRAME (frame)->face_alist;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
880 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
881
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
882 DEFUN ("set-frame-face-alist", Fset_frame_face_alist, Sset_frame_face_alist,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
883 2, 2, 0, "")
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
884 (frame, value)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
885 Lisp_Object frame, value;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
886 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
887 CHECK_FRAME (frame, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
888 XFRAME (frame)->face_alist = value;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
889 return value;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
890 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
891
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
892
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
893 DEFUN ("make-face-internal", Fmake_face_internal, Smake_face_internal, 1, 1, 0,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
894 "Create face number FACE-ID on all frames.")
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
895 (face_id)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
896 Lisp_Object face_id;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
897 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
898 Lisp_Object rest, frame;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
899 int id = XINT (face_id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
900
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
901 CHECK_NUMBER (face_id, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
902 if (id < 0 || id >= next_face_id)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
903 error ("Face id out of range");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
904
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
905 FOR_EACH_FRAME (rest, frame)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
906 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
907 if (FRAME_WIN32_P (XFRAME (frame)))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
908 ensure_face_ready (XFRAME (frame), id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
909 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
910 return Qnil;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
911 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
912
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
913
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
914 DEFUN ("set-face-attribute-internal", Fset_face_attribute_internal,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
915 Sset_face_attribute_internal, 4, 4, 0, "")
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
916 (face_id, attr_name, attr_value, frame)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
917 Lisp_Object face_id, attr_name, attr_value, frame;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
918 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
919 struct face *face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
920 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
921 int magic_p;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
922 int id;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
923 int garbaged = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
924
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
925 CHECK_FRAME (frame, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
926 CHECK_NUMBER (face_id, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
927 CHECK_SYMBOL (attr_name, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
928
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
929 f = XFRAME (frame);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
930 id = XINT (face_id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
931 if (id < 0 || id >= next_face_id)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
932 error ("Face id out of range");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
933
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
934 if (! FRAME_WIN32_P (f))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
935 return Qnil;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
936
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
937 ensure_face_ready (f, id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
938 face = FRAME_PARAM_FACES (f) [XFASTINT (face_id)];
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
939
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
940 if (EQ (attr_name, intern ("font")))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
941 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
942 XFontStruct *font = load_font (f, attr_value);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
943 if (face->font != f->output_data.win32->font)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
944 unload_font (f, face->font);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
945 face->font = font;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
946 if (frame_update_line_height (f))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
947 x_set_window_size (f, 0, f->width, f->height);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
948 /* Must clear cache, since it might contain the font
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
949 we just got rid of. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
950 garbaged = 1;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
951 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
952 else if (EQ (attr_name, intern ("foreground")))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
953 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
954 unsigned long new_color = load_color (f, attr_value);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
955 unload_color (f, face->foreground);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
956 face->foreground = new_color;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
957 garbaged = 1;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
958 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
959 else if (EQ (attr_name, intern ("background")))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
960 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
961 unsigned long new_color = load_color (f, attr_value);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
962 unload_color (f, face->background);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
963 face->background = new_color;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
964 garbaged = 1;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
965 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
966 else if (EQ (attr_name, intern ("background-pixmap")))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
967 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
968 unsigned int w, h;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
969 unsigned long new_pixmap = load_pixmap (f, attr_value, &w, &h);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
970 x_destroy_bitmap (f, face->stipple);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
971 face->stipple = (Pixmap) new_pixmap;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
972 face->pixmap_w = w;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
973 face->pixmap_h = h;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
974 garbaged = 1;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
975 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
976 else if (EQ (attr_name, intern ("underline")))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
977 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
978 int new = !NILP (attr_value);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
979 face->underline = new;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
980 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
981 else
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
982 error ("unknown face attribute");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
983
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
984 if (id == 0 || id == 1)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
985 recompute_basic_faces (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
986
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
987 /* We must redraw the frame whenever any face font or color changes,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
988 because it's possible that a merged (display) face
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
989 contains the font or color we just replaced.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
990 And we must inhibit any Expose events until the redraw is done,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
991 since they would try to use the invalid display faces. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
992 if (garbaged)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
993 SET_FRAME_GARBAGED (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
994
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
995 return Qnil;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
996 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
997
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
998 DEFUN ("internal-next-face-id", Finternal_next_face_id, Sinternal_next_face_id,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
999 0, 0, 0, "")
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1000 ()
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1001 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1002 return make_number (next_face_id++);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1003 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1004
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1005 /* Return the face id for name NAME on frame FRAME.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1006 (It should be the same for all frames,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1007 but it's as easy to use the "right" frame to look it up
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1008 as to use any other one.) */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1009
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1010 int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1011 face_name_id_number (f, name)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1012 FRAME_PTR f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1013 Lisp_Object name;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1014 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1015 Lisp_Object tem;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1016
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1017 tem = Fcdr (assq_no_quit (name, f->face_alist));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1018 if (NILP (tem))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1019 return 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1020 CHECK_VECTOR (tem, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1021 tem = XVECTOR (tem)->contents[2];
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1022 CHECK_NUMBER (tem, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1023 return XINT (tem);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1024 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1025
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1026 /* Emacs initialization. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1027
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1028 void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1029 syms_of_win32faces ()
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1030 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1031 Qface = intern ("face");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1032 staticpro (&Qface);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1033 Qmouse_face = intern ("mouse-face");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1034 staticpro (&Qmouse_face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1035 Qpixmap_spec_p = intern ("pixmap-spec-p");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1036 staticpro (&Qpixmap_spec_p);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1037
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1038 DEFVAR_INT ("region-face", ®ion_face,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1039 "Face number to use to highlight the region\n\
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1040 The region is highlighted with this face\n\
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1041 when Transient Mark mode is enabled and the mark is active.");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1042
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1043 defsubr (&Spixmap_spec_p);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1044 defsubr (&Sframe_face_alist);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1045 defsubr (&Sset_frame_face_alist);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1046 defsubr (&Smake_face_internal);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1047 defsubr (&Sset_face_attribute_internal);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1048 defsubr (&Sinternal_next_face_id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1049 }
|