16884
|
1 /* "Face" primitives on the Microsoft W32 API.
|
13434
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
|
16588
|
21 /* Ported xfaces.c for w32 - Kevin Gallo */
|
13434
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 */ );
|
21607
|
142 static void merge_face_list ( /* FRAME_PTR, struct face *, Lisp_Object */ );
|
|
143
|
|
144 extern Lisp_Object Qforeground_color, Qbackground_color;
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
145
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
146 /* Allocating, copying, and comparing struct faces. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
147
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
148 /* Allocate a new face */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
149 static struct face *
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
150 allocate_face ()
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
151 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
152 struct face *result = (struct face *) xmalloc (sizeof (struct face));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
153 bzero (result, sizeof (struct face));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
154 result->font = (XFontStruct *) FACE_DEFAULT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
155 result->foreground = FACE_DEFAULT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
156 result->background = FACE_DEFAULT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
157 result->stipple = FACE_DEFAULT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
158 return result;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
159 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
160
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
161 /* Make a new face that's a copy of an existing one. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
162 static struct face *
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
163 copy_face (face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
164 struct face *face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
165 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
166 struct face *result = allocate_face ();
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
167
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
168 result->font = face->font;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
169 result->foreground = face->foreground;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
170 result->background = face->background;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
171 result->stipple = face->stipple;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
172 result->underline = face->underline;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
173 result->pixmap_h = face->pixmap_h;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
174 result->pixmap_w = face->pixmap_w;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
175
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
176 return result;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
177 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
178
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
179 static int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
180 face_eql (face1, face2)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
181 struct face *face1, *face2;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
182 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
183 return ( face1->font == face2->font
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
184 && face1->foreground == face2->foreground
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
185 && face1->background == face2->background
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
186 && face1->stipple == face2->stipple
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
187 && face1->underline == face2->underline);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
188 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
189
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
190 /* Managing graphics contexts of faces. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
191
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
192 /* Given a computed face, construct its graphics context if necessary. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
193
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
194 struct face *
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
195 intern_face (f, face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
196 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
197 struct face *face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
198 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
199 face->gc = NULL;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
200
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
201 return face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
202 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
203
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
204 /* Clear out all graphics contexts for all computed faces
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
205 except for the default and mode line faces.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
206 This should be done from time to time just to avoid
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
207 keeping too many graphics contexts that are no longer needed. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
208
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
209 void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
210 clear_face_cache ()
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
211 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
212 /* Nothing extra */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
213 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
214
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
215 /* Allocating, freeing, and duplicating fonts, colors, and pixmaps.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
216
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
217 These functions operate on param faces only.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
218 Computed faces get their fonts, colors and pixmaps
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
219 by merging param faces. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
220
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
221 static XFontStruct *
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
222 load_font (f, name)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
223 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
224 Lisp_Object name;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
225 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
226 XFontStruct *font;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
227
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
228 if (NILP (name))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
229 return (XFontStruct *) FACE_DEFAULT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
230
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
231 CHECK_STRING (name, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
232 BLOCK_INPUT;
|
16588
|
233 font = w32_load_font (FRAME_W32_DISPLAY_INFO (f), (char *) XSTRING (name)->data);
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
234 UNBLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
235
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
236 if (! font)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
237 Fsignal (Qerror, Fcons (build_string ("undefined font"),
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
238 Fcons (name, Qnil)));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
239 return font;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
240 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
241
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
242 static void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
243 unload_font (f, font)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
244 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
245 XFontStruct *font;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
246 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
247 if (!font || font == ((XFontStruct *) FACE_DEFAULT))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
248 return;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
249
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
250 BLOCK_INPUT;
|
16588
|
251 w32_unload_font (FRAME_W32_DISPLAY_INFO (f), font);
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
252 UNBLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
253 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
254
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
255 static unsigned long
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
256 load_color (f, name)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
257 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
258 Lisp_Object name;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
259 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
260 COLORREF color;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
261 int result;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
262
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
263 if (NILP (name))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
264 return FACE_DEFAULT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
265
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
266 CHECK_STRING (name, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
267 /* if the colormap is full, defined_color will return a best match
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
268 to the values in an an existing cell. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
269 result = defined_color(f, (char *) XSTRING (name)->data, &color, 1);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
270 if (! result)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
271 Fsignal (Qerror, Fcons (build_string ("undefined color"),
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
272 Fcons (name, Qnil)));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
273 return (unsigned long) color;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
274 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
275
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
276 static void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
277 unload_color (f, pixel)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
278 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
279 unsigned long pixel;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
280 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
281 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
282
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
283 DEFUN ("pixmap-spec-p", Fpixmap_spec_p, Spixmap_spec_p, 1, 1, 0,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
284 "Return t if ARG is a valid pixmap specification.")
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
285 (arg)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
286 Lisp_Object arg;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
287 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
288 Lisp_Object height, width;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
289
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
290 return ((STRINGP (arg)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
291 || (CONSP (arg)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
292 && CONSP (XCONS (arg)->cdr)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
293 && CONSP (XCONS (XCONS (arg)->cdr)->cdr)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
294 && NILP (XCONS (XCONS (XCONS (arg)->cdr)->cdr)->cdr)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
295 && (width = XCONS (arg)->car, INTEGERP (width))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
296 && (height = XCONS (XCONS (arg)->cdr)->car, INTEGERP (height))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
297 && STRINGP (XCONS (XCONS (XCONS (arg)->cdr)->cdr)->car)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
298 && XINT (width) > 0
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
299 && XINT (height) > 0
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
300 /* The string must have enough bits for width * height. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
301 && ((XSTRING (XCONS (XCONS (XCONS (arg)->cdr)->cdr)->car)->size
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
302 * (BITS_PER_INT / sizeof (int)))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
303 >= XFASTINT (width) * XFASTINT (height))))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
304 ? Qt : Qnil);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
305 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
306
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
307 /* Load a bitmap according to NAME (which is either a file name
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
308 or a pixmap spec). Return the bitmap_id (see xfns.c)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
309 or get an error if NAME is invalid.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
310
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
311 Store the bitmap width in *W_PTR and height in *H_PTR. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
312
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
313 static long
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
314 load_pixmap (f, name, w_ptr, h_ptr)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
315 FRAME_PTR f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
316 Lisp_Object name;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
317 unsigned int *w_ptr, *h_ptr;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
318 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
319 int bitmap_id;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
320 Lisp_Object tem;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
321
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
322 if (NILP (name))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
323 return FACE_DEFAULT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
324
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
325 tem = Fpixmap_spec_p (name);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
326 if (NILP (tem))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
327 wrong_type_argument (Qpixmap_spec_p, name);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
328
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
329 BLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
330
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
331 if (CONSP (name))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
332 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
333 /* Decode a bitmap spec into a bitmap. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
334
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
335 int h, w;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
336 Lisp_Object bits;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
337
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
338 w = XINT (Fcar (name));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
339 h = XINT (Fcar (Fcdr (name)));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
340 bits = Fcar (Fcdr (Fcdr (name)));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
341
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
342 bitmap_id = x_create_bitmap_from_data (f, XSTRING (bits)->data,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
343 w, h);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
344 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
345 else
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
346 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
347 /* It must be a string -- a file name. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
348 bitmap_id = x_create_bitmap_from_file (f, name);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
349 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
350 UNBLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
351
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
352 if (bitmap_id < 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
353 Fsignal (Qerror, Fcons (build_string ("invalid or undefined bitmap"),
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
354 Fcons (name, Qnil)));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
355
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
356 *w_ptr = x_bitmap_width (f, bitmap_id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
357 *h_ptr = x_bitmap_height (f, bitmap_id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
358
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
359 return bitmap_id;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
360 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
361
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
362
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
363 /* Managing parameter face arrays for frames. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
364
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
365 void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
366 init_frame_faces (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
367 FRAME_PTR f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
368 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
369 ensure_face_ready (f, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
370 ensure_face_ready (f, 1);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
371
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
372 FRAME_N_COMPUTED_FACES (f) = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
373 FRAME_SIZE_COMPUTED_FACES (f) = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
374
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
375 new_computed_face (f, FRAME_PARAM_FACES (f)[0]);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
376 new_computed_face (f, FRAME_PARAM_FACES (f)[1]);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
377 recompute_basic_faces (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
378
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
379 /* Find another frame. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
380 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
381 Lisp_Object tail, frame, result;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
382
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
383 result = Qnil;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
384 FOR_EACH_FRAME (tail, frame)
|
16588
|
385 if (FRAME_W32_P (XFRAME (frame))
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
386 && XFRAME (frame) != f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
387 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
388 result = frame;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
389 break;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
390 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
391
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
392 /* 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
|
393 any faces other than 0 and 1, so we're okay. Otherwise, make
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
394 sure that all faces valid on the selected frame are also valid
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
395 on this new frame. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
396 if (FRAMEP (result))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
397 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
398 int i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
399 int n_faces = FRAME_N_PARAM_FACES (XFRAME (result));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
400 struct face **faces = FRAME_PARAM_FACES (XFRAME (result));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
401
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
402 for (i = 2; i < n_faces; i++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
403 if (faces[i])
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
404 ensure_face_ready (f, i);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
405 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
406 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
407 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
408
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
409
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
410 /* Called from Fdelete_frame. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
411
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
412 void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
413 free_frame_faces (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
414 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
415 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
416 int i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
417
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
418 BLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
419
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
420 for (i = 0; i < FRAME_N_PARAM_FACES (f); i++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
421 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
422 struct face *face = FRAME_PARAM_FACES (f) [i];
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
423 if (face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
424 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
425 unload_font (f, face->font);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
426 unload_color (f, face->foreground);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
427 unload_color (f, face->background);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
428 x_destroy_bitmap (f, face->stipple);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
429 xfree (face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
430 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
431 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
432 xfree (FRAME_PARAM_FACES (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
433 FRAME_PARAM_FACES (f) = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
434 FRAME_N_PARAM_FACES (f) = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
435
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
436 /* All faces in FRAME_COMPUTED_FACES use resources copied from
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
437 FRAME_PARAM_FACES; we can free them without fuss.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
438 But we do free the GCs and the face objects themselves. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
439 for (i = 0; i < FRAME_N_COMPUTED_FACES (f); i++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
440 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
441 struct face *face = FRAME_COMPUTED_FACES (f) [i];
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
442 if (face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
443 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
444 xfree (face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
445 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
446 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
447 xfree (FRAME_COMPUTED_FACES (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
448 FRAME_COMPUTED_FACES (f) = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
449 FRAME_N_COMPUTED_FACES (f) = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
450
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
451 UNBLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
452 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
453
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
454 /* Interning faces in a frame's face array. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
455
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
456 static int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
457 new_computed_face (f, new_face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
458 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
459 struct face *new_face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
460 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
461 int i = FRAME_N_COMPUTED_FACES (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
462
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
463 if (i >= FRAME_SIZE_COMPUTED_FACES (f))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
464 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
465 int new_size = i + 32;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
466
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
467 FRAME_COMPUTED_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
468 = (struct face **) (FRAME_SIZE_COMPUTED_FACES (f) == 0
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
469 ? xmalloc (new_size * sizeof (struct face *))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
470 : xrealloc (FRAME_COMPUTED_FACES (f),
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
471 new_size * sizeof (struct face *)));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
472 FRAME_SIZE_COMPUTED_FACES (f) = new_size;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
473 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
474
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
475 i = FRAME_N_COMPUTED_FACES (f)++;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
476 FRAME_COMPUTED_FACES (f)[i] = copy_face (new_face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
477 return i;
|
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
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
481 /* Find a match for NEW_FACE in a FRAME's computed face array, and add
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
482 it if we don't find one. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
483 static int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
484 intern_computed_face (f, new_face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
485 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
486 struct face *new_face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
487 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
488 int len = FRAME_N_COMPUTED_FACES (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
489 int i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
490
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
491 /* Search for a computed face already on F equivalent to FACE. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
492 for (i = 0; i < len; i++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
493 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
494 if (! FRAME_COMPUTED_FACES (f)[i])
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
495 abort ();
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
496 if (face_eql (new_face, FRAME_COMPUTED_FACES (f)[i]))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
497 return i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
498 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
499
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
500 /* We didn't find one; add a new one. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
501 return new_computed_face (f, new_face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
502 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
503
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
504 /* Make parameter face id ID valid on frame F. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
505
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
506 static void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
507 ensure_face_ready (f, id)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
508 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
509 int id;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
510 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
511 if (FRAME_N_PARAM_FACES (f) <= id)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
512 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
513 int n = id + 10;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
514 int i;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
515 if (!FRAME_N_PARAM_FACES (f))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
516 FRAME_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
517 = (struct face **) xmalloc (sizeof (struct face *) * n);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
518 else
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
519 FRAME_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
520 = (struct face **) xrealloc (FRAME_PARAM_FACES (f),
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
521 sizeof (struct face *) * n);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
522
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
523 bzero (FRAME_PARAM_FACES (f) + FRAME_N_PARAM_FACES (f),
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
524 (n - FRAME_N_PARAM_FACES (f)) * sizeof (struct face *));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
525 FRAME_N_PARAM_FACES (f) = n;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
526 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
527
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
528 if (FRAME_PARAM_FACES (f) [id] == 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
529 FRAME_PARAM_FACES (f) [id] = allocate_face ();
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
530 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
531
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
532 /* Return non-zero if FONT1 and FONT2 have the same width.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
533 We do not check the height, because we can now deal with
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
534 different heights.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
535 We assume that they're both character-cell fonts. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
536
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
537 int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
538 same_size_fonts (font1, font2)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
539 XFontStruct *font1, *font2;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
540 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
541 return (FONT_WIDTH(font1) == FONT_WIDTH(font2));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
542 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
543
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
544 /* Update the line_height of frame F according to the biggest font in
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
545 any face. Return nonzero if if line_height changes. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
546
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
547 int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
548 frame_update_line_height (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
549 FRAME_PTR f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
550 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
551 int i;
|
16588
|
552 int biggest = FONT_HEIGHT (f->output_data.w32->font);
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
553
|
16588
|
554 for (i = 0; i < f->output_data.w32->n_param_faces; i++)
|
|
555 if (f->output_data.w32->param_faces[i] != 0
|
|
556 && f->output_data.w32->param_faces[i]->font != (XFontStruct *) FACE_DEFAULT)
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
557 {
|
16588
|
558 int height = FONT_HEIGHT (f->output_data.w32->param_faces[i]->font);
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
559 if (height > biggest)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
560 biggest = height;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
561 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
562
|
16588
|
563 if (biggest == f->output_data.w32->line_height)
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
564 return 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
565
|
16588
|
566 f->output_data.w32->line_height = biggest;
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
567 return 1;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
568 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
569
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
570 /* Modify face TO by copying from FROM all properties which have
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
571 nondefault settings. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
572
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
573 static void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
574 merge_faces (from, to)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
575 struct face *from, *to;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
576 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
577 /* Only merge the font if it's the same width as the base font.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
578 Otherwise ignore it, since we can't handle it properly. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
579 if (from->font != (XFontStruct *) FACE_DEFAULT
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
580 && same_size_fonts (from->font, to->font))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
581 to->font = from->font;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
582 if (from->foreground != FACE_DEFAULT)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
583 to->foreground = from->foreground;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
584 if (from->background != FACE_DEFAULT)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
585 to->background = from->background;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
586 if (from->stipple != FACE_DEFAULT)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
587 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
588 to->stipple = from->stipple;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
589 to->pixmap_h = from->pixmap_h;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
590 to->pixmap_w = from->pixmap_w;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
591 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
592 if (from->underline)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
593 to->underline = from->underline;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
594 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
595
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
596 /* Set up the basic set of facial parameters, based on the frame's
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
597 data; all faces are deltas applied to this. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
598
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
599 static void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
600 compute_base_face (f, face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
601 FRAME_PTR f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
602 struct face *face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
603 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
604 face->gc = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
605 face->foreground = FRAME_FOREGROUND_PIXEL (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
606 face->background = FRAME_BACKGROUND_PIXEL (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
607 face->font = FRAME_FONT (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
608 face->stipple = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
609 face->underline = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
610 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
611
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
612 /* Return the face ID to use to display a special glyph which selects
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
613 FACE_CODE as the face ID, assuming that ordinarily the face would
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
614 be CURRENT_FACE. F is the frame. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
615
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
616 int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
617 compute_glyph_face (f, face_code, current_face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
618 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
619 int face_code, current_face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
620 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
621 struct face face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
622
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
623 face = *FRAME_COMPUTED_FACES (f)[current_face];
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
624
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
625 if (face_code >= 0 && face_code < FRAME_N_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
626 && FRAME_PARAM_FACES (f) [face_code] != 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
627 merge_faces (FRAME_PARAM_FACES (f) [face_code], &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
628
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
629 return intern_computed_face (f, &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
630 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
631
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
632 /* Return the face ID to use to display a special glyph which selects
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
633 FACE_CODE as the face ID, assuming that ordinarily the face would
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
634 be CURRENT_FACE. F is the frame. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
635
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
636 int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
637 compute_glyph_face_1 (f, face_name, current_face)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
638 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
639 Lisp_Object face_name;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
640 int current_face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
641 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
642 struct face face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
643
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
644 face = *FRAME_COMPUTED_FACES (f)[current_face];
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
645
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
646 if (!NILP (face_name))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
647 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
648 int facecode = face_name_id_number (f, face_name);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
649 if (facecode >= 0 && facecode < FRAME_N_PARAM_FACES (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
650 && FRAME_PARAM_FACES (f) [facecode] != 0)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
651 merge_faces (FRAME_PARAM_FACES (f) [facecode], &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
652 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
653
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
654 return intern_computed_face (f, &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
655 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
656
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
657 /* Return the face ID associated with a buffer position POS.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
658 Store into *ENDPTR the position at which a different face is needed.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
659 This does not take account of glyphs that specify their own face codes.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
660 F is the frame in use for display, and W is a window displaying
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
661 the current buffer.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
662
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
663 REGION_BEG, REGION_END delimit the region, so it can be highlighted.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
664
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
665 LIMIT is a position not to scan beyond. That is to limit
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
666 the time this function can take.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
667
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
668 If MOUSE is nonzero, use the character's mouse-face, not its face. */
|
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
|
21607
|
751 merge_face_list (f, &face, prop);
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
752
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
753 noverlays = sort_overlays (overlay_vec, noverlays, w);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
754
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
755 /* Now merge the overlay data in that order. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
756 for (i = 0; i < noverlays; i++)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
757 {
|
21607
|
758 Lisp_Object oend;
|
|
759 int oendpos;
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
760
|
21607
|
761 prop = Foverlay_get (overlay_vec[i], propname);
|
|
762 merge_face_list (f, &face, prop);
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
763
|
21607
|
764 oend = OVERLAY_END (overlay_vec[i]);
|
|
765 oendpos = OVERLAY_POSITION (oend);
|
|
766 if (oendpos < endpos)
|
|
767 endpos = oendpos;
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
768 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
769
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
770 if (pos >= region_beg && pos < region_end)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
771 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
772 if (region_end < endpos)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
773 endpos = region_end;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
774 if (region_face >= 0 && region_face < next_face_id)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
775 merge_faces (FRAME_PARAM_FACES (f)[region_face], &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
776 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
777
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
778 *endptr = endpos;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
779
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
780 return intern_computed_face (f, &face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
781 }
|
21607
|
782
|
|
783 static void
|
|
784 merge_face_list (f, face, prop)
|
|
785 FRAME_PTR f;
|
|
786 struct face *face;
|
|
787 Lisp_Object prop;
|
|
788 {
|
|
789 Lisp_Object length;
|
|
790 int len;
|
|
791 Lisp_Object *faces;
|
|
792 int j;
|
|
793
|
|
794 if (CONSP (prop)
|
|
795 && ! STRINGP (XCONS (prop)->cdr))
|
|
796 {
|
|
797 /* We have a list of faces, merge them in reverse order. */
|
|
798
|
|
799 length = Fsafe_length (prop);
|
|
800 len = XFASTINT (length);
|
|
801
|
|
802 /* Put them into an array. */
|
|
803 faces = (Lisp_Object *) alloca (len * sizeof (Lisp_Object));
|
|
804 for (j = 0; j < len; j++)
|
|
805 {
|
|
806 faces[j] = Fcar (prop);
|
|
807 prop = Fcdr (prop);
|
|
808 }
|
|
809 /* So that we can merge them in the reverse order. */
|
|
810 }
|
|
811 else
|
|
812 {
|
|
813 faces = (Lisp_Object *) alloca (sizeof (Lisp_Object));
|
|
814 faces[0] = prop;
|
|
815 len = 1;
|
|
816 }
|
|
817
|
|
818 for (j = len - 1; j >= 0; j--)
|
|
819 {
|
|
820 if (CONSP (faces[j]))
|
|
821 {
|
|
822 if (EQ (XCONS (faces[j])->car, Qbackground_color))
|
|
823 face->background = load_color (f, XCONS (faces[j])->cdr);
|
|
824 if (EQ (XCONS (faces[j])->car, Qforeground_color))
|
|
825 face->foreground = load_color (f, XCONS (faces[j])->cdr);
|
|
826 }
|
|
827 else
|
|
828 {
|
|
829 int facecode = face_name_id_number (f, faces[j]);
|
|
830 if (facecode >= 0 && facecode < FRAME_N_PARAM_FACES (f)
|
|
831 && FRAME_PARAM_FACES (f) [facecode] != 0)
|
|
832 merge_faces (FRAME_PARAM_FACES (f) [facecode], face);
|
|
833 }
|
|
834 }
|
|
835 }
|
|
836
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
837
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
838 /* Recompute the GC's for the default and modeline faces.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
839 We call this after changing frame parameters on which those GC's
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
840 depend. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
841
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
842 void
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
843 recompute_basic_faces (f)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
844 FRAME_PTR f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
845 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
846 /* If the frame's faces haven't been initialized yet, don't worry about
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
847 this stuff. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
848 if (FRAME_N_PARAM_FACES (f) < 2)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
849 return;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
850
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
851 BLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
852
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
853 compute_base_face (f, FRAME_DEFAULT_FACE (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
854 compute_base_face (f, FRAME_MODE_LINE_FACE (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
855
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
856 merge_faces (FRAME_DEFAULT_PARAM_FACE (f), FRAME_DEFAULT_FACE (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
857 merge_faces (FRAME_MODE_LINE_PARAM_FACE (f), FRAME_MODE_LINE_FACE (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
858
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
859 intern_face (f, FRAME_DEFAULT_FACE (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
860 intern_face (f, FRAME_MODE_LINE_FACE (f));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
861
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
862 UNBLOCK_INPUT;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
863 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
864
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
865
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
866
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
867 /* Lisp interface. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
868
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
869 DEFUN ("frame-face-alist", Fframe_face_alist, Sframe_face_alist, 1, 1, 0,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
870 "")
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
871 (frame)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
872 Lisp_Object frame;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
873 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
874 CHECK_FRAME (frame, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
875 return XFRAME (frame)->face_alist;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
876 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
877
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
878 DEFUN ("set-frame-face-alist", Fset_frame_face_alist, Sset_frame_face_alist,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
879 2, 2, 0, "")
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
880 (frame, value)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
881 Lisp_Object frame, value;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
882 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
883 CHECK_FRAME (frame, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
884 XFRAME (frame)->face_alist = value;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
885 return value;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
886 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
887
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
888
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
889 DEFUN ("make-face-internal", Fmake_face_internal, Smake_face_internal, 1, 1, 0,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
890 "Create face number FACE-ID on all frames.")
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
891 (face_id)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
892 Lisp_Object face_id;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
893 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
894 Lisp_Object rest, frame;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
895 int id = XINT (face_id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
896
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
897 CHECK_NUMBER (face_id, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
898 if (id < 0 || id >= next_face_id)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
899 error ("Face id out of range");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
900
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
901 FOR_EACH_FRAME (rest, frame)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
902 {
|
16588
|
903 if (FRAME_W32_P (XFRAME (frame)))
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
904 ensure_face_ready (XFRAME (frame), id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
905 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
906 return Qnil;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
907 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
908
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
909
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
910 DEFUN ("set-face-attribute-internal", Fset_face_attribute_internal,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
911 Sset_face_attribute_internal, 4, 4, 0, "")
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
912 (face_id, attr_name, attr_value, frame)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
913 Lisp_Object face_id, attr_name, attr_value, frame;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
914 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
915 struct face *face;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
916 struct frame *f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
917 int magic_p;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
918 int id;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
919 int garbaged = 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
920
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
921 CHECK_FRAME (frame, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
922 CHECK_NUMBER (face_id, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
923 CHECK_SYMBOL (attr_name, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
924
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
925 f = XFRAME (frame);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
926 id = XINT (face_id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
927 if (id < 0 || id >= next_face_id)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
928 error ("Face id out of range");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
929
|
16588
|
930 if (! FRAME_W32_P (f))
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
931 return Qnil;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
932
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
933 ensure_face_ready (f, id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
934 face = FRAME_PARAM_FACES (f) [XFASTINT (face_id)];
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
935
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
936 if (EQ (attr_name, intern ("font")))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
937 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
938 XFontStruct *font = load_font (f, attr_value);
|
16588
|
939 if (face->font != f->output_data.w32->font)
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
940 unload_font (f, face->font);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
941 face->font = font;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
942 if (frame_update_line_height (f))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
943 x_set_window_size (f, 0, f->width, f->height);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
944 /* Must clear cache, since it might contain the font
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
945 we just got rid of. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
946 garbaged = 1;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
947 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
948 else if (EQ (attr_name, intern ("foreground")))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
949 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
950 unsigned long new_color = load_color (f, attr_value);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
951 unload_color (f, face->foreground);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
952 face->foreground = new_color;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
953 garbaged = 1;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
954 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
955 else if (EQ (attr_name, intern ("background")))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
956 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
957 unsigned long new_color = load_color (f, attr_value);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
958 unload_color (f, face->background);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
959 face->background = new_color;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
960 garbaged = 1;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
961 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
962 else if (EQ (attr_name, intern ("background-pixmap")))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
963 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
964 unsigned int w, h;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
965 unsigned long new_pixmap = load_pixmap (f, attr_value, &w, &h);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
966 x_destroy_bitmap (f, face->stipple);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
967 face->stipple = (Pixmap) new_pixmap;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
968 face->pixmap_w = w;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
969 face->pixmap_h = h;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
970 garbaged = 1;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
971 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
972 else if (EQ (attr_name, intern ("underline")))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
973 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
974 int new = !NILP (attr_value);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
975 face->underline = new;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
976 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
977 else
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
978 error ("unknown face attribute");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
979
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
980 if (id == 0 || id == 1)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
981 recompute_basic_faces (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
982
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
983 /* We must redraw the frame whenever any face font or color changes,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
984 because it's possible that a merged (display) face
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
985 contains the font or color we just replaced.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
986 And we must inhibit any Expose events until the redraw is done,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
987 since they would try to use the invalid display faces. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
988 if (garbaged)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
989 SET_FRAME_GARBAGED (f);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
990
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
991 return Qnil;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
992 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
993
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
994 DEFUN ("internal-next-face-id", Finternal_next_face_id, Sinternal_next_face_id,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
995 0, 0, 0, "")
|
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 return make_number (next_face_id++);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
999 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1000
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1001 /* Return the face id for name NAME on frame FRAME.
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1002 (It should be the same for all frames,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1003 but it's as easy to use the "right" frame to look it up
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1004 as to use any other one.) */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1005
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1006 int
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1007 face_name_id_number (f, name)
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1008 FRAME_PTR f;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1009 Lisp_Object name;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1010 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1011 Lisp_Object tem;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1012
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1013 tem = Fcdr (assq_no_quit (name, f->face_alist));
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1014 if (NILP (tem))
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1015 return 0;
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1016 CHECK_VECTOR (tem, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1017 tem = XVECTOR (tem)->contents[2];
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1018 CHECK_NUMBER (tem, 0);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1019 return XINT (tem);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1020 }
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1021
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1022 /* Emacs initialization. */
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1023
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1024 void
|
16588
|
1025 syms_of_w32faces ()
|
13434
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1026 {
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1027 Qface = intern ("face");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1028 staticpro (&Qface);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1029 Qmouse_face = intern ("mouse-face");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1030 staticpro (&Qmouse_face);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1031 Qpixmap_spec_p = intern ("pixmap-spec-p");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1032 staticpro (&Qpixmap_spec_p);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1033
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1034 DEFVAR_INT ("region-face", ®ion_face,
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1035 "Face number to use to highlight the region\n\
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1036 The region is highlighted with this face\n\
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1037 when Transient Mark mode is enabled and the mark is active.");
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1038
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1039 defsubr (&Spixmap_spec_p);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1040 defsubr (&Sframe_face_alist);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1041 defsubr (&Sset_frame_face_alist);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1042 defsubr (&Smake_face_internal);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1043 defsubr (&Sset_face_attribute_internal);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1044 defsubr (&Sinternal_next_face_id);
|
Geoff Voelker <voelker@cs.washington.edu>
parents:
diff
changeset
|
1045 }
|