vfs: check userland buffers before reading them.
[haiku.git] / docs / develop / servers / app_server / FontServer.htm
blob13e0fe5d347bb0ff37eb26ee59e28a131f359b7a
1 <HTML>
2 <HEAD>
3 <TITLE>FontServer.htm</TITLE>
4 <style type="text/css">
5 <!--
6 .Default {background-color: rgb(255,255,255); color: rgb(0,0,0); font-family: 'Dutch801 Rm BT'; font-size: 12pt}
7 .OBOS-Function-Def {background-color: rgb(255,255,255); color: rgb(0,0,0); font-family: 'Dutch801 Rm BT'; font-size: 16pt}
8 .OBOS-Title {background-color: rgb(255,255,255); color: rgb(0,128,0); font-family: 'Dutch801 Rm BT'; font-size: 24pt}
9 .Text-Background {background-color: rgb(255,255,255)}
10 .GR-Default {}
11 .Body {margin: 0px}
12 .Footer {margin: 0px}
13 .Header {margin: 0px}
14 .WP-Default {text-align: left; text-indent: 0px; margin-left: 0px; margin-right: 0px}
15 -->
16 </style>
17 </HEAD>
18 <BODY BGCOLOR="#ffffff">
19 <DIV class="sheet" id="Sheet 1">
20 <P class="Body" style="margin: 0px"><span class="OBOS-Title">FontServer class</span><span style="color: rgb(0,0,0); font-size: 24pt"></span></P>
21 <P class="Body" style="margin: 0px"><BR>
22 </P>
23 <P class="Body" style="margin: 0px">The FontServer provides the base functionality for providing font support for the rest of the system and insulates the rest of the server from having to deal too much with FreeType.</P>
24 <P class="Body" style="margin: 0px"><BR>
25 <HR>
26 </P>
27 <P class="Body" style="margin: 0px">Member Functions</P>
28 <P class="Body" style="margin: 0px"><BR>
29 </P>
30 <TABLE WIDTH=621 HEIGHT=306 BORDER=1 CELLPADDING=1 CELLSPACING=2>
31 <TR>
32 <TD WIDTH=225 HEIGHT=17>
33 <P class="Body" style="margin: 0px">FontServer(void)</P>
34 </TD>
35 <TD WIDTH=240 HEIGHT=17>
36 <P class="Body" style="margin: 0px">~FontServer(void)</P>
37 </TD>
38 </TR>
39 <TR>
40 <TD WIDTH=225 HEIGHT=17>
41 <P class="Body" style="margin: 0px">void Lock(void)</P>
42 </TD>
43 <TD WIDTH=240 HEIGHT=17>
44 <P class="Body" style="margin: 0px">void Unlock(void)</P>
45 </TD>
46 </TR>
47 <TR>
48 <TD WIDTH=225 HEIGHT=17>
49 <P class="Body" style="margin: 0px">void SaveList(void)</P>
50 </TD>
51 <TD WIDTH=240 HEIGHT=17>
52 <P class="Body" style="margin: 0px">status_t ScanDirectory(const char *path)</P>
53 </TD>
54 </TR>
55 <TR>
56 <TD WIDTH=225 HEIGHT=47>
57 <P class="Body" style="margin: 0px">FontStyle *GetFont(font_family family, font_style face)</P>
58 </TD>
59 <TD WIDTH=240 HEIGHT=47>
60 <P class="Body" style="margin: 0px">FontInstance *GetInstance(font_family family, font_style face, int16 size, int16 rotation, int16 shear)</P>
61 </TD>
62 </TR>
63 <TR>
64 <TD WIDTH=225 HEIGHT=17>
65 <P class="Body" style="margin: 0px">int32 CountFamiles(void)</P>
66 </TD>
67 <TD WIDTH=240 HEIGHT=17>
68 <P class="Body" style="margin: 0px">status_t IsInitialized(void)</P>
69 </TD>
70 </TR>
71 <TR>
72 <TD WIDTH=225 HEIGHT=32>
73 <P class="Body" style="margin: 0px">int32 CountStyles(font_family family)</P>
74 </TD>
75 <TD WIDTH=240 HEIGHT=32>
76 <P class="Body" style="margin: 0px">FontStyle *GetStyle(font_family family, font_style style)</P>
77 </TD>
78 </TR>
79 <TR>
80 <TD WIDTH=225 HEIGHT=17>
81 <P class="Body" style="margin: 0px">void RemoveFamily(const char *family)</P>
82 </TD>
83 <TD WIDTH=240 HEIGHT=17>
84 <P class="Body" style="margin: 0px">FontFamily *_FindFamily(const char *name)</P>
85 </TD>
86 </TR>
87 <TR>
88 <TD WIDTH=225 HEIGHT=17>
89 <P class="Body" style="margin: 0px">ServerFont *GetSystemPlain(void)</P>
90 </TD>
91 <TD WIDTH=240 HEIGHT=17>
92 <P class="Body" style="margin: 0px">ServerFont *GetSystemBold(void)</P>
93 </TD>
94 </TR>
95 <TR>
96 <TD WIDTH=225 HEIGHT=32>
97 <P class="Body" style="margin: 0px">ServerFont *GetSystemFixed(void)</P>
98 </TD>
99 <TD WIDTH=240 HEIGHT=32>
100 <P class="Body" style="margin: 0px">bool SetSystemPlain(const char *family, const char *style, float size)</P>
101 </TD>
102 </TR>
103 <TR>
104 <TD WIDTH=225 HEIGHT=17>
105 <P class="Body" style="margin: 0px">void RemoveUnusedFamilies(void)</P>
106 </TD>
107 <TD WIDTH=240 HEIGHT=17>
108 <P class="Body" style="margin: 0px">bool FontsNeedUpdated(void)</P>
109 </TD>
110 </TR>
111 </TABLE>
112 <P class="Body" style="margin: 0px"><BR>
113 <BR>
114 <HR>
115 </P>
116 <P class="Body" style="margin: 0px"><span class="OBOS-Function-Def">FontServer(void)</span></P>
117 <P class="Body" style="margin: 0px"><BR>
118 1) Create access semaphore</P>
119 <P class="Body" style="margin: 0px">2) Call FT_Init_FreeType()</P>
120 <P class="Body" style="margin: 0px">3) If no error initializing the FreeType library, set init flag to true</P>
121 <P class="Body" style="margin: 0px"><BR>
122 <BR>
123 <span class="OBOS-Function-Def">~FontServer(void)</span></P>
124 <P class="Body" style="margin: 0px"><BR>
125 1) Call FT_Done_FreeType()</P>
126 <P class="Body" style="margin: 0px"><BR>
127 <BR>
128 <span class="OBOS-Function-Def">void Lock(void)</span></P>
129 <P class="Body" style="margin: 0px"><span class="OBOS-Function-Def">void Unlock(void)</span></P>
130 <P class="Body" style="margin: 0px"><BR>
131 These functions simply acquire and release the internal access semaphore.</P>
132 <P class="Body" style="margin: 0px"><BR>
133 <BR>
134 <span class="OBOS-Function-Def">void SaveList(void)</span></P>
135 <P class="Body" style="margin: 0px"><BR>
136 Saves the list of all scanned and valid font families and styles to disk</P>
137 <P class="Body" style="margin: 0px"><BR>
138 1) create a BMessage for storing font family data (hereafter, the font message)</P>
139 <P class="Body" style="margin: 0px">2) create a BMessage for storing a list of font family messages (hereafter, the list message)</P>
140 <P class="Body" style="margin: 0px">3) create a boolean tuned flag and a boolean fixed flag</P>
141 <P class="Body" style="margin: 0px">4) Iterate through all families</P>
142 <P class="Body" style="margin: 0px"> A) for each family, get its name and add its name to the font message as "name"</P>
143 <P class="Body" style="margin: 0px"> B) iterate through the families styles</P>
144 <P class="Body" style="margin: 0px"> a) get the style's name, and if valid, add it to the font message as "styles"</P>
145 <P class="Body" style="margin: 0px"> b) if IsTuned and IsScalable, set the tuned flag to true</P>
146 <P class="Body" style="margin: 0px"> c) if IsFixedWidth, set the fixed flag to true</P>
147 <P class="Body" style="margin: 0px"> C) if the tuned flag is set, add a boolean true to the font message as "tuned"</P>
148 <P class="Body" style="margin: 0px"> D) if the fixed flag is set, add a boolean true to the font message as "fixed"</P>
149 <P class="Body" style="margin: 0px"> E) add the font message to the list message as "family"</P>
150 <P class="Body" style="margin: 0px"> F) empty the font message</P>
151 <P class="Body" style="margin: 0px">5) Create a BFile from the path definition SERVER_FONT_LIST for Read/Write, creating the file if nonexistent and erasing any existing one</P>
152 <P class="Body" style="margin: 0px">6) Flatten the list message to the created BFile object</P>
153 <P class="Body" style="margin: 0px">7) Set the needs_update flag to false</P>
154 <P class="Body" style="margin: 0px"><BR>
155 <BR>
156 <span class="OBOS-Function-Def">status_t ScanDirectory(const char *path)</span></P>
157 <P class="Body" style="margin: 0px"><BR>
158 ScanDirectory is where the brunt of the work of the FontServer is done - scans the directory of all fonts which can be loaded.</P>
159 <P class="Body" style="margin: 0px"><BR>
160 1) Make a BDirectory object pointer at the path parameter. If the init code is not B_OK, return it.</P>
161 <P class="Body" style="margin: 0px">2) Enter a while() loop, iterating through each entry in the given directory, executing as follows:</P>
162 <P class="Body" style="margin: 0px"> a) Ensure that the entry is not '.' or '..'</P>
163 <P class="Body" style="margin: 0px"> b) Call FT_New_Face on the entry's full path</P>
164 <P class="Body" style="margin: 0px"> c) If a valid FT_Face is returned, iterate through to see if there are any supported character mappings in the current entry.</P>
165 <P class="Body" style="margin: 0px"> d) If there are no supported character mappings, dump the supported mappings to debug output, call FT_Done_Face(), and continue to the next entry</P>
166 <P class="Body" style="margin: 0px"> e) See if the entry's family has been added to the family list. If it hasn't, create one and add it.</P>
167 <P class="Body" style="margin: 0px"> f) Check to see if the font's style has been added to its family. If so, call FT_Done_Face, and continue to the next entry</P>
168 <P class="Body" style="margin: 0px"> g) If the style has not been added, create a new SFont for that family and face, increment the font count, and continue to the next entry.</P>
169 <P class="Body" style="margin: 0px">3) set the needs_update flag to true</P>
170 <P class="Body" style="margin: 0px">4) Return B_OK</P>
171 <P class="Body" style="margin: 0px"><BR>
172 Supported character mappings are Windows and Apple Unicode, Windows symbol, and Apple Roman character mappings, in order of preference from first to last.</P>
173 <P class="Body" style="margin: 0px"><BR>
174 <BR>
175 <span class="OBOS-Function-Def">FontStyle *GetFont(font_family family, font_style face)</span></P>
176 <P class="Body" style="margin: 0px"><BR>
177 Returns an FontStyle object for the specified family and style or NULL if not found.</P>
178 <P class="Body" style="margin: 0px"><BR>
179 1) Call _FindFamily() for the given family</P>
180 <P class="Body" style="margin: 0px">2) If non-NULL, call its FindStyle() method</P>
181 <P class="Body" style="margin: 0px">3) Return the result</P>
182 <P class="Body" style="margin: 0px"><BR>
183 <BR>
184 <span class="OBOS-Function-Def">FontInstance *GetInstance(font_family family, font_style face, int16 size, int16 rotation, int16 shear)</span></P>
185 <P class="Body" style="margin: 0px"><BR>
186 Returns a usable instance of a specified font object with specified properties.</P>
187 <P class="Body" style="margin: 0px"><BR>
188 1) Duplicates and performs the code found in GetFont</P>
189 <P class="Body" style="margin: 0px">2) Assuming that the FontStyle object is non-NULL, it calls its GetInstance method and returns the result.</P>
190 <P class="Body" style="margin: 0px"><BR>
191 <BR>
192 <span class="OBOS-Function-Def">int32 CountFamilies(void)</span></P>
193 <P class="Body" style="margin: 0px"><BR>
194 Returns the number of valid font families available to the system.</P>
195 <P class="Body" style="margin: 0px"><BR>
196 1) Return the number of items in the family list</P>
197 <P class="Body" style="margin: 0px"><BR>
198 <BR>
199 <span class="OBOS-Function-Def">status_t IsInitialized(void)</span></P>
200 <P class="Body" style="margin: 0px"><BR>
201 Returns the initialization status variable</P>
202 <P class="Body" style="margin: 0px"><BR>
203 <BR>
204 <span class="OBOS-Function-Def">int32 CountStyles(font_family family)</span></P>
205 <P class="Body" style="margin: 0px"><BR>
206 Returns the number of styles available for a given font family.</P>
207 <P class="Body" style="margin: 0px"><BR>
208 1) Call _FindFamily() to get the appropriate font family</P>
209 <P class="Body" style="margin: 0px">2) If non-NULL, call its return the result of its CountStyles method</P>
210 <P class="Body" style="margin: 0px"><BR>
211 <BR>
212 <span class="OBOS-Function-Def">FontStyle *GetStyle(font_family family, font_style style)</span></P>
213 <P class="Body" style="margin: 0px"><BR>
214 Gets the FontStyle object of the family, style, and flags.</P>
215 <P class="Body" style="margin: 0px"><BR>
216 1) Call _FindFamily() to get the appropriate font family</P>
217 <P class="Body" style="margin: 0px">2) If non-NULL, call the family's GetStyle method on the font_style parameter and return the result</P>
218 <P class="Body" style="margin: 0px">3) If family is NULL, return NULL</P>
219 <P class="Body" style="margin: 0px"><BR>
220 <BR>
221 <span class="OBOS-Function-Def">void RemoveFamily(const char *family)</span></P>
222 <P class="Body" style="margin: 0px"><BR>
223 Removes a font family from the family list</P>
224 <P class="Body" style="margin: 0px"><BR>
225 1) Look up font family in the family list via _FindFamily()</P>
226 <P class="Body" style="margin: 0px">2) If it exists, delete it</P>
227 <P class="Body" style="margin: 0px"><BR>
228 <BR>
229 protected:</P>
230 <P class="Body" style="margin: 0px"><BR>
231 <span class="OBOS-Function-Def">FontFamily *_FindFamily(const char *name)</span></P>
232 <P class="Body" style="margin: 0px"><BR>
233 Looks up a FontFamily object based on its family name. Returns NULL if not found.</P>
234 <P class="Body" style="margin: 0px"><BR>
235 1) Call the family list's find() method.</P>
236 <P class="Body" style="margin: 0px">2) Return the appropriate FontFamily object or NULL if not found.</P>
237 <P class="Body" style="margin: 0px"><BR>
238 <BR>
239 <span class="OBOS-Function-Def">ServerFont *GetSystemPlain(void)</span></P>
240 <P class="Body" style="margin: 0px"><span class="OBOS-Function-Def">ServerFont *GetSystemBold(void)</span></P>
241 <P class="Body" style="margin: 0px"><span class="OBOS-Function-Def">ServerFont *GetSystemFixed(void)</span></P>
242 <P class="Body" style="margin: 0px"><BR>
243 These return a copy of a pointer to the system-wide ServerFont objects which represent the appropriate system font settings. It is the responsibility of the caller to delete the object returned. NULL is returned if no setting has been set for a particular system font.</P>
244 <P class="Body" style="margin: 0px"><BR>
245 <span class="OBOS-Function-Def">bool SetSystemPlain(const char *family, const char *style, float size)</span></P>
246 <P class="Body" style="margin: 0px"><span class="OBOS-Function-Def">bool SetSystemBold(const char *family, const char *style, float size)</span></P>
247 <P class="Body" style="margin: 0px"><span class="OBOS-Function-Def">bool SetSystemFixed(const char *family, const char *style, float size)</span></P>
248 <P class="Body" style="margin: 0px"><BR>
249 The system fonts settings may be set via these calls by specifying the family, style, and size. They return true if everything worked out ok and false if not. Settings are not changed if false is returned.</P>
250 <P class="Body" style="margin: 0px"><BR>
251 1) Call _FindFamily on the family parameter. if NULL, return false</P>
252 <P class="Body" style="margin: 0px">2) Call the family's GetStyle member. if NULL, return false</P>
253 <P class="Body" style="margin: 0px">3) if the appropriate system font pointer is non-NULL, delete it</P>
254 <P class="Body" style="margin: 0px">4) call the style's Instantiate member with the size parameter</P>
255 <P class="Body" style="margin: 0px"><BR>
256 <BR>
257 <span class="OBOS-Function-Def">void RemoveUnusedFamilies(void)</span></P>
258 <P class="Body" style="margin: 0px"><BR>
259 The purpose of this function is to allow for a complete rescan of the fonts in the appropriate directories.</P>
260 <P class="Body" style="margin: 0px"><BR>
261 1) Iterate through the family list</P>
262 <P class="Body" style="margin: 0px"> A) Get a family</P>
263 <P class="Body" style="margin: 0px"> B) if it has no dependents, remove it from the list and delete it</P>
264 <P class="Body" style="margin: 0px">2) Set the needs_update flag to true</P>
265 <P class="Body" style="margin: 0px"><BR>
266 <BR>
267 <span class="OBOS-Function-Def">bool FontsNeedUpdated(void)</span></P>
268 <P class="Body" style="margin: 0px"><BR>
269 Returns the value of the needs_update flag</P>
270 <DIV class="layer" id="Layer 1">
271 </DIV>
272 </DIV>
273 </BODY>
274 </HTML>