diff options
author | Laurentiu Palcu <laurentiu.palcu@intel.com> | 2013-01-31 10:32:40 +0200 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2013-02-06 09:37:24 +0000 |
commit | e46f33688c011e5e087267a18437316c05b22f14 (patch) | |
tree | 9d5a89241ba48eee7b16314e926d4f31b48b4eea /meta/recipes-graphics/fontconfig | |
parent | 5479aa4869a4888ff8409d6d73b1eff2074f5127 (diff) | |
download | poky-e46f33688c011e5e087267a18437316c05b22f14.tar.gz |
fontconfig: add sysroot option to fc-cache and fc-cat
This is needed in order to be able to generate the cache on host.
Additionally, remove the volatile config file, as /var/cache was moved
out of tmpfs.
[YOCTO #2599]
(From OE-Core rev: b675e9917b0a1e774c95ee7a946f515c5a996b59)
Signed-off-by: Laurentiu Palcu <laurentiu.palcu@intel.com>
Signed-off-by: Saul Wold <sgw@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/recipes-graphics/fontconfig')
3 files changed, 735 insertions, 10 deletions
diff --git a/meta/recipes-graphics/fontconfig/fontconfig-2.10.2/97_fontconfig b/meta/recipes-graphics/fontconfig/fontconfig-2.10.2/97_fontconfig deleted file mode 100644 index 2993959dbb..0000000000 --- a/meta/recipes-graphics/fontconfig/fontconfig-2.10.2/97_fontconfig +++ /dev/null | |||
@@ -1 +0,0 @@ | |||
1 | d root root 0755 /var/cache/fontconfig none | ||
diff --git a/meta/recipes-graphics/fontconfig/fontconfig-2.10.2/Add-sysroot-option-to-fc-cache-and-fc-cat.patch b/meta/recipes-graphics/fontconfig/fontconfig-2.10.2/Add-sysroot-option-to-fc-cache-and-fc-cat.patch new file mode 100644 index 0000000000..f0b3b7fc32 --- /dev/null +++ b/meta/recipes-graphics/fontconfig/fontconfig-2.10.2/Add-sysroot-option-to-fc-cache-and-fc-cat.patch | |||
@@ -0,0 +1,731 @@ | |||
1 | Upstream-Status: Pending | ||
2 | |||
3 | From a5eeeafb623a5508d2745f89aaf69118799f7e5c Mon Sep 17 00:00:00 2001 | ||
4 | From: Laurentiu Palcu <laurentiu.palcu@intel.com> | ||
5 | Date: Mon, 28 Jan 2013 11:42:56 +0200 | ||
6 | Subject: [PATCH] Add sysroot option to fc-cache and fc-cat | ||
7 | |||
8 | Whether one needs to generate the font cache offline and then deploy the | ||
9 | image to a target or do some testing in a separate rootfs, the sysroot | ||
10 | option will facilitate that. | ||
11 | |||
12 | Suppose you've got a rootfs in the following directory: | ||
13 | /path/to/test/rootfs. In order to contain the fc-cache generation to | ||
14 | that particular directory, the following command can be used: | ||
15 | |||
16 | fc-cache --sysroot=/path/to/test/rootfs | ||
17 | |||
18 | That will make fc-cache to prepend the sysroot directory to all paths | ||
19 | during scanning. For example, instead of searching /etc/fonts/ directory | ||
20 | for configuration files, it will look in /path/to/test/rootfs/etc/fonts. | ||
21 | The paths found in fonts.conf will also be prepended with the sysroot. | ||
22 | |||
23 | However, the generated cache files will not contain any references to | ||
24 | sysroot. This way, one can generate the font cache offline and then deploy | ||
25 | the image to target. Or, simply, use it for various tests without | ||
26 | polluting the system/user cache files. | ||
27 | |||
28 | In order to inspect the cache generated using the sysroot option, one | ||
29 | has to use fc-cat like below (for example): | ||
30 | |||
31 | fc-cat --sysroot=/path/to/test/rootfs | ||
32 | /path/to/test/rootfs/var/cache/fontconfig/* | ||
33 | |||
34 | Signed-off-by: Laurentiu Palcu <laurentiu.palcu@intel.com> | ||
35 | --- | ||
36 | fc-cache/fc-cache.c | 63 ++++++++++++++++++++++++++++------- | ||
37 | fc-cat/fc-cat.c | 77 +++++++++++++++++++++++++++++++++++------- | ||
38 | fc-lang/fc-lang.c | 1 + | ||
39 | fontconfig/fontconfig.h | 6 ++++ | ||
40 | src/fccache.c | 85 +++++++++++++++++++++++++++++++++++++++++++---- | ||
41 | src/fccfg.c | 52 +++++++++++++++++++++++++++++ | ||
42 | src/fcfreetype.c | 4 +++ | ||
43 | src/fcstr.c | 27 +++++++++++++++ | ||
44 | 8 files changed, 285 insertions(+), 30 deletions(-) | ||
45 | |||
46 | diff --git a/fc-cache/fc-cache.c b/fc-cache/fc-cache.c | ||
47 | index 9fb383b..a91e1f1 100644 | ||
48 | --- a/fc-cache/fc-cache.c | ||
49 | +++ b/fc-cache/fc-cache.c | ||
50 | @@ -68,6 +68,7 @@ const struct option longopts[] = { | ||
51 | {"force", 0, 0, 'f'}, | ||
52 | {"really-force", 0, 0, 'r'}, | ||
53 | {"system-only", 0, 0, 's'}, | ||
54 | + {"sysroot", 1, 0, 'y'}, | ||
55 | {"version", 0, 0, 'V'}, | ||
56 | {"verbose", 0, 0, 'v'}, | ||
57 | {"help", 0, 0, 'h'}, | ||
58 | @@ -85,26 +86,28 @@ usage (char *program, int error) | ||
59 | { | ||
60 | FILE *file = error ? stderr : stdout; | ||
61 | #if HAVE_GETOPT_LONG | ||
62 | - fprintf (file, "usage: %s [-frsvVh] [--force|--really-force] [--system-only] [--verbose] [--version] [--help] [dirs]\n", | ||
63 | + fprintf (file, "usage: %s [-frsvVh] [-y SYSROOT] [--force|--really-force] [--system-only] [--sysroot=SYSROOT] [--verbose] [--version] [--help] [dirs]\n", | ||
64 | program); | ||
65 | #else | ||
66 | - fprintf (file, "usage: %s [-frsvVh] [dirs]\n", | ||
67 | + fprintf (file, "usage: %s [-frsvVh] [-y SYSROOT] [dirs]\n", | ||
68 | program); | ||
69 | #endif | ||
70 | fprintf (file, "Build font information caches in [dirs]\n" | ||
71 | "(all directories in font configuration by default).\n"); | ||
72 | fprintf (file, "\n"); | ||
73 | #if HAVE_GETOPT_LONG | ||
74 | - fprintf (file, " -f, --force scan directories with apparently valid caches\n"); | ||
75 | - fprintf (file, " -r, --really-force erase all existing caches, then rescan\n"); | ||
76 | - fprintf (file, " -s, --system-only scan system-wide directories only\n"); | ||
77 | - fprintf (file, " -v, --verbose display status information while busy\n"); | ||
78 | - fprintf (file, " -V, --version display font config version and exit\n"); | ||
79 | - fprintf (file, " -h, --help display this help and exit\n"); | ||
80 | + fprintf (file, " -f, --force scan directories with apparently valid caches\n"); | ||
81 | + fprintf (file, " -r, --really-force erase all existing caches, then rescan\n"); | ||
82 | + fprintf (file, " -s, --system-only scan system-wide directories only\n"); | ||
83 | + fprintf (file, " -y, --sysroot=SYSROOT for scanning, prefix all paths with SYSROOT. The cache file will not contain the SYSROOT!\n"); | ||
84 | + fprintf (file, " -v, --verbose display status information while busy\n"); | ||
85 | + fprintf (file, " -V, --version display font config version and exit\n"); | ||
86 | + fprintf (file, " -h, --help display this help and exit\n"); | ||
87 | #else | ||
88 | fprintf (file, " -f (force) scan directories with apparently valid caches\n"); | ||
89 | fprintf (file, " -r, (really force) erase all existing caches, then rescan\n"); | ||
90 | fprintf (file, " -s (system) scan system-wide directories only\n"); | ||
91 | + fprintf (file, " -y SYSROOT for scanning, prefix all paths with SYSROOT. The cache file will not contain the SYSROOT!\n"); | ||
92 | fprintf (file, " -v (verbose) display status information while busy\n"); | ||
93 | fprintf (file, " -V (version) display font config version and exit\n"); | ||
94 | fprintf (file, " -h (help) display this help and exit\n"); | ||
95 | @@ -125,7 +128,7 @@ scanDirs (FcStrList *list, FcConfig *config, FcBool force, FcBool really_force, | ||
96 | struct stat statb; | ||
97 | FcBool was_valid; | ||
98 | int i; | ||
99 | - | ||
100 | + FcChar8 *sysroot = FcConfigGetSysRoot (); | ||
101 | /* | ||
102 | * Now scan all of the directories into separate databases | ||
103 | * and write out the results | ||
104 | @@ -227,7 +230,22 @@ scanDirs (FcStrList *list, FcConfig *config, FcBool force, FcBool really_force, | ||
105 | continue; | ||
106 | } | ||
107 | for (i = 0; i < FcCacheNumSubdir (cache); i++) | ||
108 | - FcStrSetAdd (subdirs, FcCacheSubdir (cache, i)); | ||
109 | + { | ||
110 | + const FcChar8 *subdir = FcCacheSubdir (cache, i); | ||
111 | + if (sysroot) | ||
112 | + { | ||
113 | + subdir = FcStrPlus (sysroot, subdir); | ||
114 | + if (!subdir) | ||
115 | + { | ||
116 | + fprintf (stderr, "malloc failure\n"); | ||
117 | + return ++ret; | ||
118 | + } | ||
119 | + } | ||
120 | + | ||
121 | + FcStrSetAdd (subdirs, subdir); | ||
122 | + if (sysroot) | ||
123 | + FcStrFree ((FcChar8 *) subdir); | ||
124 | + } | ||
125 | |||
126 | FcDirCacheUnload (cache); | ||
127 | |||
128 | @@ -277,6 +295,7 @@ main (int argc, char **argv) | ||
129 | FcBool really_force = FcFalse; | ||
130 | FcBool systemOnly = FcFalse; | ||
131 | FcConfig *config; | ||
132 | + FcChar8 *sysroot = NULL; | ||
133 | int i; | ||
134 | int changed; | ||
135 | int ret; | ||
136 | @@ -284,9 +303,9 @@ main (int argc, char **argv) | ||
137 | int c; | ||
138 | |||
139 | #if HAVE_GETOPT_LONG | ||
140 | - while ((c = getopt_long (argc, argv, "frsVvh", longopts, NULL)) != -1) | ||
141 | + while ((c = getopt_long (argc, argv, "frsy:Vvh", longopts, NULL)) != -1) | ||
142 | #else | ||
143 | - while ((c = getopt (argc, argv, "frsVvh")) != -1) | ||
144 | + while ((c = getopt (argc, argv, "frsy:Vvh")) != -1) | ||
145 | #endif | ||
146 | { | ||
147 | switch (c) { | ||
148 | @@ -299,6 +318,9 @@ main (int argc, char **argv) | ||
149 | case 's': | ||
150 | systemOnly = FcTrue; | ||
151 | break; | ||
152 | + case 'y': | ||
153 | + sysroot = FcStrCopy ((const FcChar8*) optarg); | ||
154 | + break; | ||
155 | case 'V': | ||
156 | fprintf (stderr, "fontconfig version %d.%d.%d\n", | ||
157 | FC_MAJOR, FC_MINOR, FC_REVISION); | ||
158 | @@ -319,6 +341,21 @@ main (int argc, char **argv) | ||
159 | |||
160 | if (systemOnly) | ||
161 | FcConfigEnableHome (FcFalse); | ||
162 | + | ||
163 | + if (sysroot) | ||
164 | + { | ||
165 | + FcChar8 *canon_sysroot; | ||
166 | + canon_sysroot = FcConfigSetSysRoot(sysroot); | ||
167 | + FcStrFree (sysroot); | ||
168 | + if (!canon_sysroot) | ||
169 | + { | ||
170 | + fprintf (stderr, "Cannot set the sysroot. Out of memory!\n"); | ||
171 | + return 1; | ||
172 | + } | ||
173 | + | ||
174 | + sysroot = canon_sysroot; | ||
175 | + } | ||
176 | + | ||
177 | config = FcInitLoadConfig (); | ||
178 | if (!config) | ||
179 | { | ||
180 | @@ -378,6 +415,8 @@ main (int argc, char **argv) | ||
181 | * library, and there aren't any signals flying around here. | ||
182 | */ | ||
183 | FcConfigDestroy (config); | ||
184 | + if (sysroot) | ||
185 | + FcStrFree (sysroot); | ||
186 | FcFini (); | ||
187 | if (changed) | ||
188 | sleep (2); | ||
189 | diff --git a/fc-cat/fc-cat.c b/fc-cat/fc-cat.c | ||
190 | index 72912b7..4b4f0f0 100644 | ||
191 | --- a/fc-cat/fc-cat.c | ||
192 | +++ b/fc-cat/fc-cat.c | ||
193 | @@ -57,6 +57,7 @@ const struct option longopts[] = { | ||
194 | {"verbose", 0, 0, 'v'}, | ||
195 | {"recurse", 0, 0, 'r'}, | ||
196 | {"help", 0, 0, 'h'}, | ||
197 | + {"sysroot", 1, 0, 'y'}, | ||
198 | {NULL,0,0,0}, | ||
199 | }; | ||
200 | #else | ||
201 | @@ -150,11 +151,11 @@ usage (char *program, int error) | ||
202 | { | ||
203 | FILE *file = error ? stderr : stdout; | ||
204 | #if HAVE_GETOPT_LONG | ||
205 | - fprintf (file, "usage: %s [-rv] [--recurse] [--verbose] [*-%s" FC_CACHE_SUFFIX "|directory]...\n", | ||
206 | + fprintf (file, "usage: %s [-rv] [--recurse] [--verbose] [--sysroot=SYSROOT] [*-%s" FC_CACHE_SUFFIX "|directory]...\n", | ||
207 | program, FC_ARCHITECTURE); | ||
208 | fprintf (file, " %s [-Vh] [--version] [--help]\n", program); | ||
209 | #else | ||
210 | - fprintf (file, "usage: %s [-rvVh] [*-%s" FC_CACHE_SUFFIX "|directory]...\n", | ||
211 | + fprintf (file, "usage: %s [-rvVh] [-y SYSROOT] [*-%s" FC_CACHE_SUFFIX "|directory]...\n", | ||
212 | program, FC_ARCHITECTURE); | ||
213 | #endif | ||
214 | fprintf (file, "Reads font information cache from:\n"); | ||
215 | @@ -162,15 +163,17 @@ usage (char *program, int error) | ||
216 | fprintf (file, " 2) related to a particular font directory\n"); | ||
217 | fprintf (file, "\n"); | ||
218 | #if HAVE_GETOPT_LONG | ||
219 | - fprintf (file, " -r, --recurse recurse into subdirectories\n"); | ||
220 | - fprintf (file, " -v, --verbose be verbose\n"); | ||
221 | - fprintf (file, " -V, --version display font config version and exit\n"); | ||
222 | - fprintf (file, " -h, --help display this help and exit\n"); | ||
223 | + fprintf (file, " -r, --recurse recurse into subdirectories\n"); | ||
224 | + fprintf (file, " -v, --verbose be verbose\n"); | ||
225 | + fprintf (file, " -V, --version display font config version and exit\n"); | ||
226 | + fprintf (file, " -h, --help display this help and exit\n"); | ||
227 | + fprintf (file, " -y, --sysroot=SYSROOT needed if the cache was generated using --sysroot\n"); | ||
228 | #else | ||
229 | fprintf (file, " -r (recurse) recurse into subdirectories\n"); | ||
230 | fprintf (file, " -v (verbose) be verbose\n"); | ||
231 | fprintf (file, " -V (version) display font config version and exit\n"); | ||
232 | fprintf (file, " -h (help) display this help and exit\n"); | ||
233 | + fprintf (file, " -y SYSROOT needed if the cache was generated using --sysroot\n"); | ||
234 | #endif | ||
235 | exit (error); | ||
236 | } | ||
237 | @@ -262,13 +265,14 @@ main (int argc, char **argv) | ||
238 | int verbose = 0; | ||
239 | int recurse = 0; | ||
240 | FcBool first = FcTrue; | ||
241 | + FcChar8 *sysroot = NULL; | ||
242 | #if HAVE_GETOPT_LONG || HAVE_GETOPT | ||
243 | int c; | ||
244 | |||
245 | #if HAVE_GETOPT_LONG | ||
246 | - while ((c = getopt_long (argc, argv, "Vvrh", longopts, NULL)) != -1) | ||
247 | + while ((c = getopt_long (argc, argv, "Vvrhy:", longopts, NULL)) != -1) | ||
248 | #else | ||
249 | - while ((c = getopt (argc, argv, "Vvrh")) != -1) | ||
250 | + while ((c = getopt (argc, argv, "Vvrhy:")) != -1) | ||
251 | #endif | ||
252 | { | ||
253 | switch (c) { | ||
254 | @@ -284,6 +288,9 @@ main (int argc, char **argv) | ||
255 | break; | ||
256 | case 'h': | ||
257 | usage (argv[0], 0); | ||
258 | + case 'y': | ||
259 | + sysroot = FcStrCopy ((const FcChar8*) optarg); | ||
260 | + break; | ||
261 | default: | ||
262 | usage (argv[0], 1); | ||
263 | } | ||
264 | @@ -293,6 +300,20 @@ main (int argc, char **argv) | ||
265 | i = 1; | ||
266 | #endif | ||
267 | |||
268 | + if (sysroot) | ||
269 | + { | ||
270 | + FcChar8 *canon_sysroot; | ||
271 | + canon_sysroot = FcConfigSetSysRoot(sysroot); | ||
272 | + FcStrFree (sysroot); | ||
273 | + if (!canon_sysroot) | ||
274 | + { | ||
275 | + fprintf (stderr, "%s: malloc failure\n", argv[0]); | ||
276 | + return 1; | ||
277 | + } | ||
278 | + | ||
279 | + sysroot = canon_sysroot; | ||
280 | + } | ||
281 | + | ||
282 | config = FcInitLoadConfig (); | ||
283 | if (!config) | ||
284 | { | ||
285 | @@ -348,6 +369,7 @@ main (int argc, char **argv) | ||
286 | int j; | ||
287 | FcChar8 *cache_file = NULL; | ||
288 | struct stat file_stat; | ||
289 | + const FcChar8 *base_dir = NULL; | ||
290 | |||
291 | if (FcFileIsDir (arg)) | ||
292 | cache = FcDirCacheLoad (arg, config, &cache_file); | ||
293 | @@ -364,9 +386,34 @@ main (int argc, char **argv) | ||
294 | fs = FcCacheCopySet (cache); | ||
295 | for (j = 0; j < FcCacheNumSubdir (cache); j++) | ||
296 | { | ||
297 | - FcStrSetAdd (dirs, FcCacheSubdir (cache, j)); | ||
298 | + const FcChar8 *subdir = FcCacheSubdir (cache, j); | ||
299 | + if (sysroot) | ||
300 | + { | ||
301 | + subdir = FcStrPlus (sysroot, subdir); | ||
302 | + if (!subdir) | ||
303 | + { | ||
304 | + fprintf (stderr, "%s: malloc failure\n", argv[0]); | ||
305 | + return 1; | ||
306 | + } | ||
307 | + } | ||
308 | + | ||
309 | + FcStrSetAdd (dirs, subdir); | ||
310 | if (recurse) | ||
311 | - FcStrSetAdd (args, FcCacheSubdir (cache, j)); | ||
312 | + FcStrSetAdd (args, subdir); | ||
313 | + | ||
314 | + if (sysroot) | ||
315 | + FcStrFree ((FcChar8 *) subdir); | ||
316 | + } | ||
317 | + | ||
318 | + base_dir = FcCacheDir (cache); | ||
319 | + if (sysroot) | ||
320 | + { | ||
321 | + base_dir = FcStrPlus (sysroot, base_dir); | ||
322 | + if (!base_dir) | ||
323 | + { | ||
324 | + fprintf (stderr, "%s: malloc failure\n", argv[0]); | ||
325 | + return 1; | ||
326 | + } | ||
327 | } | ||
328 | |||
329 | if (verbose) | ||
330 | @@ -374,10 +421,13 @@ main (int argc, char **argv) | ||
331 | if (!first) | ||
332 | printf ("\n"); | ||
333 | printf ("Directory: %s\nCache: %s\n--------\n", | ||
334 | - FcCacheDir(cache), cache_file ? cache_file : arg); | ||
335 | + base_dir, cache_file ? cache_file : arg); | ||
336 | first = FcFalse; | ||
337 | } | ||
338 | - cache_print_set (fs, dirs, FcCacheDir (cache), verbose); | ||
339 | + cache_print_set (fs, dirs, base_dir, verbose); | ||
340 | + | ||
341 | + if (sysroot) | ||
342 | + FcStrFree ((FcChar8 *) base_dir); | ||
343 | |||
344 | FcStrSetDestroy (dirs); | ||
345 | |||
346 | @@ -387,6 +437,9 @@ main (int argc, char **argv) | ||
347 | FcStrFree (cache_file); | ||
348 | } | ||
349 | |||
350 | + if (sysroot) | ||
351 | + FcStrFree (sysroot); | ||
352 | + | ||
353 | FcFini (); | ||
354 | return 0; | ||
355 | } | ||
356 | diff --git a/fc-lang/fc-lang.c b/fc-lang/fc-lang.c | ||
357 | index 93200c4..e74e856 100644 | ||
358 | --- a/fc-lang/fc-lang.c | ||
359 | +++ b/fc-lang/fc-lang.c | ||
360 | @@ -22,6 +22,7 @@ | ||
361 | * PERFORMANCE OF THIS SOFTWARE. | ||
362 | */ | ||
363 | |||
364 | +#define FC_LANG_C | ||
365 | #include "fccharset.c" | ||
366 | #include "fcstr.c" | ||
367 | #include "fcserialize.c" | ||
368 | diff --git a/fontconfig/fontconfig.h b/fontconfig/fontconfig.h | ||
369 | index 266986c..b05f6ca 100644 | ||
370 | --- a/fontconfig/fontconfig.h | ||
371 | +++ b/fontconfig/fontconfig.h | ||
372 | @@ -417,6 +417,12 @@ FcConfigSubstitute (FcConfig *config, | ||
373 | FcPattern *p, | ||
374 | FcMatchKind kind); | ||
375 | |||
376 | +FcPublic FcChar8 * | ||
377 | +FcConfigSetSysRoot (const FcChar8 *sysroot); | ||
378 | + | ||
379 | +FcPublic FcChar8 * | ||
380 | +FcConfigGetSysRoot (void); | ||
381 | + | ||
382 | /* fccharset.c */ | ||
383 | FcPublic FcCharSet* | ||
384 | FcCharSetCreate (void); | ||
385 | diff --git a/src/fccache.c b/src/fccache.c | ||
386 | index 81985df..c3dcc72 100644 | ||
387 | --- a/src/fccache.c | ||
388 | +++ b/src/fccache.c | ||
389 | @@ -93,6 +93,14 @@ FcDirCacheBasename (const FcChar8 * dir, FcChar8 cache_base[CACHEBASE_LEN]) | ||
390 | FcChar8 *hex_hash; | ||
391 | int cnt; | ||
392 | struct MD5Context ctx; | ||
393 | + FcChar8 *sysroot = FcConfigGetSysRoot(); | ||
394 | + | ||
395 | + /* | ||
396 | + * remove sysroot when generating the hex hash | ||
397 | + */ | ||
398 | + if (sysroot && !strncmp ((const char*) sysroot, (const char*) dir, | ||
399 | + strlen ((const char*) sysroot))) | ||
400 | + dir += strlen((const char*) sysroot); | ||
401 | |||
402 | MD5Init (&ctx); | ||
403 | MD5Update (&ctx, (const unsigned char *)dir, strlen ((const char *) dir)); | ||
404 | @@ -505,16 +513,31 @@ static FcBool | ||
405 | FcCacheTimeValid (FcCache *cache, struct stat *dir_stat) | ||
406 | { | ||
407 | struct stat dir_static; | ||
408 | + FcChar8 *dir = FcCacheDir (cache); | ||
409 | + FcChar8 *sysroot = FcConfigGetSysRoot (); | ||
410 | + | ||
411 | + if (sysroot) | ||
412 | + { | ||
413 | + dir = FcStrPlus (sysroot, dir); | ||
414 | + if (!dir) | ||
415 | + return FcFalse; | ||
416 | + } | ||
417 | |||
418 | if (!dir_stat) | ||
419 | { | ||
420 | - if (FcStatChecksum (FcCacheDir (cache), &dir_static) < 0) | ||
421 | + if (FcStatChecksum (dir, &dir_static) < 0) | ||
422 | + { | ||
423 | + if (sysroot) | ||
424 | + FcStrFree (dir); | ||
425 | return FcFalse; | ||
426 | + } | ||
427 | dir_stat = &dir_static; | ||
428 | } | ||
429 | if (FcDebug () & FC_DBG_CACHE) | ||
430 | printf ("FcCacheTimeValid dir \"%s\" cache checksum %d dir checksum %d\n", | ||
431 | - FcCacheDir (cache), cache->checksum, (int) dir_stat->st_mtime); | ||
432 | + dir, cache->checksum, (int) dir_stat->st_mtime); | ||
433 | + if (sysroot) | ||
434 | + FcStrFree (dir); | ||
435 | return cache->checksum == (int) dir_stat->st_mtime; | ||
436 | } | ||
437 | |||
438 | @@ -716,9 +739,27 @@ FcDirCacheBuild (FcFontSet *set, const FcChar8 *dir, struct stat *dir_stat, FcSt | ||
439 | FcChar8 *dir_serialize; | ||
440 | intptr_t *dirs_serialize; | ||
441 | FcFontSet *set_serialize; | ||
442 | + FcChar8 *sysroot = FcConfigGetSysRoot (); | ||
443 | + FcStrSet *dirs_without_sysroot; | ||
444 | |||
445 | if (!serialize) | ||
446 | return NULL; | ||
447 | + | ||
448 | + if (sysroot) | ||
449 | + { | ||
450 | + dir += strlen ((const char*) sysroot); | ||
451 | + | ||
452 | + dirs_without_sysroot = FcStrSetCreate (); | ||
453 | + if (!dirs_without_sysroot) | ||
454 | + return NULL; | ||
455 | + | ||
456 | + for (i = 0; i < dirs->num; i++) | ||
457 | + FcStrSetAdd (dirs_without_sysroot, | ||
458 | + dirs->strs[i] + strlen ((const char*) sysroot)); | ||
459 | + | ||
460 | + dirs = dirs_without_sysroot; | ||
461 | + } | ||
462 | + | ||
463 | /* | ||
464 | * Space for cache structure | ||
465 | */ | ||
466 | @@ -792,11 +833,17 @@ FcDirCacheBuild (FcFontSet *set, const FcChar8 *dir, struct stat *dir_stat, FcSt | ||
467 | |||
468 | FcCacheInsert (cache, NULL); | ||
469 | |||
470 | + if (sysroot) | ||
471 | + FcStrSetDestroy(dirs_without_sysroot); | ||
472 | + | ||
473 | return cache; | ||
474 | |||
475 | bail2: | ||
476 | free (cache); | ||
477 | bail1: | ||
478 | + if (sysroot) | ||
479 | + FcStrSetDestroy(dirs_without_sysroot); | ||
480 | + | ||
481 | FcSerializeDestroy (serialize); | ||
482 | return NULL; | ||
483 | } | ||
484 | @@ -844,6 +891,14 @@ FcDirCacheWrite (FcCache *cache, FcConfig *config) | ||
485 | struct stat cache_stat; | ||
486 | int magic; | ||
487 | int written; | ||
488 | + FcChar8 *sysroot = FcConfigGetSysRoot (); | ||
489 | + | ||
490 | + if (sysroot) | ||
491 | + { | ||
492 | + dir = FcStrPlus (sysroot, dir); | ||
493 | + if (!dir) | ||
494 | + return FcFalse; | ||
495 | + } | ||
496 | |||
497 | /* | ||
498 | * Write it to the first directory in the list which is writable | ||
499 | @@ -851,7 +906,7 @@ FcDirCacheWrite (FcCache *cache, FcConfig *config) | ||
500 | |||
501 | list = FcStrListCreate (config->cacheDirs); | ||
502 | if (!list) | ||
503 | - return FcFalse; | ||
504 | + goto bail0; | ||
505 | while ((test_dir = FcStrListNext (list))) { | ||
506 | if (access ((char *) test_dir, W_OK) == 0) | ||
507 | { | ||
508 | @@ -886,12 +941,12 @@ FcDirCacheWrite (FcCache *cache, FcConfig *config) | ||
509 | } | ||
510 | FcStrListDone (list); | ||
511 | if (!cache_dir) | ||
512 | - return FcFalse; | ||
513 | + goto bail0; | ||
514 | |||
515 | FcDirCacheBasename (dir, cache_base); | ||
516 | cache_hashed = FcStrPlus (cache_dir, cache_base); | ||
517 | if (!cache_hashed) | ||
518 | - return FcFalse; | ||
519 | + goto bail0; | ||
520 | |||
521 | if (FcDebug () & FC_DBG_CACHE) | ||
522 | printf ("FcDirCacheWriteDir dir \"%s\" file \"%s\"\n", | ||
523 | @@ -948,6 +1003,8 @@ FcDirCacheWrite (FcCache *cache, FcConfig *config) | ||
524 | FcStrFree (cache_hashed); | ||
525 | FcAtomicUnlock (atomic); | ||
526 | FcAtomicDestroy (atomic); | ||
527 | + if (sysroot) | ||
528 | + FcStrFree (dir); | ||
529 | return FcTrue; | ||
530 | |||
531 | bail5: | ||
532 | @@ -958,6 +1015,9 @@ FcDirCacheWrite (FcCache *cache, FcConfig *config) | ||
533 | FcAtomicDestroy (atomic); | ||
534 | bail1: | ||
535 | FcStrFree (cache_hashed); | ||
536 | + bail0: | ||
537 | + if (sysroot) | ||
538 | + FcStrFree (dir); | ||
539 | return FcFalse; | ||
540 | } | ||
541 | |||
542 | @@ -997,7 +1057,8 @@ FcDirCacheClean (const FcChar8 *cache_dir, FcBool verbose) | ||
543 | while ((ent = readdir (d))) | ||
544 | { | ||
545 | FcChar8 *file_name; | ||
546 | - const FcChar8 *target_dir; | ||
547 | + FcChar8 *target_dir; | ||
548 | + FcChar8 *sysroot = FcConfigGetSysRoot (); | ||
549 | |||
550 | if (ent->d_name[0] == '.') | ||
551 | continue; | ||
552 | @@ -1025,6 +1086,16 @@ FcDirCacheClean (const FcChar8 *cache_dir, FcBool verbose) | ||
553 | else | ||
554 | { | ||
555 | target_dir = FcCacheDir (cache); | ||
556 | + if (sysroot) | ||
557 | + { | ||
558 | + target_dir = FcStrPlus (sysroot, target_dir); | ||
559 | + if (!target_dir) | ||
560 | + { | ||
561 | + ret = FcFalse; | ||
562 | + FcStrFree (file_name); | ||
563 | + break; | ||
564 | + } | ||
565 | + } | ||
566 | if (stat ((char *) target_dir, &target_stat) < 0) | ||
567 | { | ||
568 | if (verbose || FcDebug () & FC_DBG_CACHE) | ||
569 | @@ -1043,6 +1114,8 @@ FcDirCacheClean (const FcChar8 *cache_dir, FcBool verbose) | ||
570 | } | ||
571 | FcDirCacheUnload (cache); | ||
572 | FcStrFree (file_name); | ||
573 | + if (sysroot) | ||
574 | + FcStrFree (target_dir); | ||
575 | } | ||
576 | |||
577 | closedir (d); | ||
578 | diff --git a/src/fccfg.c b/src/fccfg.c | ||
579 | index d3752e5..ad97c05 100644 | ||
580 | --- a/src/fccfg.c | ||
581 | +++ b/src/fccfg.c | ||
582 | @@ -37,6 +37,7 @@ | ||
583 | #endif | ||
584 | |||
585 | FcConfig *_fcConfig; | ||
586 | +static FcChar8 *_FcConfigSysRoot = NULL; | ||
587 | |||
588 | FcConfig * | ||
589 | FcConfigCreate (void) | ||
590 | @@ -1716,6 +1717,7 @@ FcConfigFileExists (const FcChar8 *dir, const FcChar8 *file) | ||
591 | { | ||
592 | FcChar8 *path; | ||
593 | int size, osize; | ||
594 | + FcChar8 *sysroot = _FcConfigSysRoot; | ||
595 | |||
596 | if (!dir) | ||
597 | dir = (FcChar8 *) ""; | ||
598 | @@ -1747,6 +1749,19 @@ FcConfigFileExists (const FcChar8 *dir, const FcChar8 *file) | ||
599 | strcat ((char *) path, (char *) file); | ||
600 | |||
601 | FcMemAlloc (FC_MEM_STRING, osize); | ||
602 | + | ||
603 | + if (sysroot && | ||
604 | + strncmp ((const char*) sysroot, (const char*) path, | ||
605 | + strlen ((const char *) sysroot))) | ||
606 | + { | ||
607 | + FcChar8 *new_path = FcStrPlus (sysroot, path); | ||
608 | + FcStrFree (path); | ||
609 | + if (!new_path) | ||
610 | + return 0; | ||
611 | + | ||
612 | + path = new_path; | ||
613 | + } | ||
614 | + | ||
615 | if (access ((char *) path, R_OK) == 0) | ||
616 | return path; | ||
617 | |||
618 | @@ -2217,6 +2232,43 @@ FcConfigAcceptFont (FcConfig *config, | ||
619 | return FcFalse; | ||
620 | return FcTrue; | ||
621 | } | ||
622 | + | ||
623 | + | ||
624 | +FcPublic FcChar8 * | ||
625 | +FcConfigSetSysRoot (const FcChar8 *sysroot) | ||
626 | +{ | ||
627 | + FcChar8 *old_sysroot, *new_sysroot; | ||
628 | + | ||
629 | + if (!sysroot) | ||
630 | + return NULL; | ||
631 | + | ||
632 | + new_sysroot = FcStrCopyFilename(sysroot); | ||
633 | + if (!new_sysroot) | ||
634 | + return NULL; | ||
635 | + | ||
636 | + old_sysroot = _FcConfigSysRoot; | ||
637 | + | ||
638 | + if (old_sysroot && | ||
639 | + !strcmp ((const char *) new_sysroot, (const char *) old_sysroot)) | ||
640 | + { | ||
641 | + FcStrFree (new_sysroot); | ||
642 | + return old_sysroot; | ||
643 | + } | ||
644 | + | ||
645 | + _FcConfigSysRoot = new_sysroot; | ||
646 | + | ||
647 | + if (old_sysroot) | ||
648 | + FcStrFree (old_sysroot); | ||
649 | + | ||
650 | + return new_sysroot; | ||
651 | +} | ||
652 | + | ||
653 | +FcPublic FcChar8 * | ||
654 | +FcConfigGetSysRoot (void) | ||
655 | +{ | ||
656 | + return _FcConfigSysRoot; | ||
657 | +} | ||
658 | + | ||
659 | #define __fccfg__ | ||
660 | #include "fcaliastail.h" | ||
661 | #undef __fccfg__ | ||
662 | diff --git a/src/fcfreetype.c b/src/fcfreetype.c | ||
663 | index fb2b0f2..c497be5 100644 | ||
664 | --- a/src/fcfreetype.c | ||
665 | +++ b/src/fcfreetype.c | ||
666 | @@ -1124,6 +1124,7 @@ FcFreeTypeQueryFace (const FT_Face face, | ||
667 | |||
668 | FcChar8 *style = 0; | ||
669 | int st; | ||
670 | + FcChar8 *sysroot = FcConfigGetSysRoot(); | ||
671 | |||
672 | pat = FcPatternCreate (); | ||
673 | if (!pat) | ||
674 | @@ -1340,6 +1341,9 @@ FcFreeTypeQueryFace (const FT_Face face, | ||
675 | ++nstyle; | ||
676 | } | ||
677 | |||
678 | + if (sysroot) | ||
679 | + file += strlen ((const char*) sysroot); | ||
680 | + | ||
681 | if (!nfamily) | ||
682 | { | ||
683 | FcChar8 *start, *end; | ||
684 | diff --git a/src/fcstr.c b/src/fcstr.c | ||
685 | index 037960d..62ceae6 100644 | ||
686 | --- a/src/fcstr.c | ||
687 | +++ b/src/fcstr.c | ||
688 | @@ -1170,6 +1170,8 @@ FcBool | ||
689 | FcStrSetAddFilename (FcStrSet *set, const FcChar8 *s) | ||
690 | { | ||
691 | FcChar8 *new = FcStrCopyFilename (s); | ||
692 | + | ||
693 | +#ifdef FC_LANG_C | ||
694 | if (!new) | ||
695 | return FcFalse; | ||
696 | if (!_FcStrSetAppend (set, new)) | ||
697 | @@ -1177,6 +1179,31 @@ FcStrSetAddFilename (FcStrSet *set, const FcChar8 *s) | ||
698 | FcStrFree (new); | ||
699 | return FcFalse; | ||
700 | } | ||
701 | +#else | ||
702 | + FcChar8 *full; | ||
703 | + FcChar8 *sysroot = FcConfigGetSysRoot(); | ||
704 | + | ||
705 | + if (!new) | ||
706 | + return FcFalse; | ||
707 | + | ||
708 | + if (sysroot && strncmp ((const char *) sysroot, (const char *) new, | ||
709 | + strlen ((const char*) sysroot))) | ||
710 | + { | ||
711 | + full = FcStrPlus(sysroot, new); | ||
712 | + FcStrFree(new); | ||
713 | + if (!full) | ||
714 | + return FcFalse; | ||
715 | + } | ||
716 | + else | ||
717 | + full = new; | ||
718 | + | ||
719 | + if (!_FcStrSetAppend (set, full)) | ||
720 | + { | ||
721 | + FcStrFree (full); | ||
722 | + return FcFalse; | ||
723 | + } | ||
724 | +#endif | ||
725 | + | ||
726 | return FcTrue; | ||
727 | } | ||
728 | |||
729 | -- | ||
730 | 1.7.9.5 | ||
731 | |||
diff --git a/meta/recipes-graphics/fontconfig/fontconfig_2.10.2.bb b/meta/recipes-graphics/fontconfig/fontconfig_2.10.2.bb index ceb5119065..607cf9e6da 100644 --- a/meta/recipes-graphics/fontconfig/fontconfig_2.10.2.bb +++ b/meta/recipes-graphics/fontconfig/fontconfig_2.10.2.bb | |||
@@ -14,17 +14,18 @@ BUGTRACKER = "https://bugs.freedesktop.org/enter_bug.cgi?product=fontconfig" | |||
14 | LICENSE = "MIT-style & MIT & PD" | 14 | LICENSE = "MIT-style & MIT & PD" |
15 | LIC_FILES_CHKSUM = "file://COPYING;md5=dc5b39c592e47a22dbec44855988d2a0 \ | 15 | LIC_FILES_CHKSUM = "file://COPYING;md5=dc5b39c592e47a22dbec44855988d2a0 \ |
16 | file://src/fcfreetype.c;endline=45;md5=5d9513e3196a1fbfdfa94051c09dfc84 \ | 16 | file://src/fcfreetype.c;endline=45;md5=5d9513e3196a1fbfdfa94051c09dfc84 \ |
17 | file://src/fccache.c;beginline=1109;endline=1124;md5=0326cfeb4a7333dd4dd25fbbc4b9f27f" | 17 | file://src/fccache.c;beginline=1182;endline=1197;md5=0326cfeb4a7333dd4dd25fbbc4b9f27f" |
18 | 18 | ||
19 | SECTION = "libs" | 19 | SECTION = "libs" |
20 | 20 | ||
21 | DEPENDS = "expat freetype zlib" | 21 | DEPENDS = "expat freetype zlib" |
22 | 22 | ||
23 | PR = "r0" | 23 | PR = "r1" |
24 | 24 | ||
25 | SRC_URI = "http://fontconfig.org/release/fontconfig-${PV}.tar.gz \ | 25 | SRC_URI = "http://fontconfig.org/release/fontconfig-${PV}.tar.gz \ |
26 | file://Add-sysroot-option-to-fc-cache-and-fc-cat.patch \ | ||
26 | file://fix-pkgconfig.patch \ | 27 | file://fix-pkgconfig.patch \ |
27 | file://97_fontconfig" | 28 | " |
28 | 29 | ||
29 | SRC_URI[md5sum] = "025e08b3d7fe45c433de5718e441ed15" | 30 | SRC_URI[md5sum] = "025e08b3d7fe45c433de5718e441ed15" |
30 | SRC_URI[sha256sum] = "5c3bf994bb6d6303bbf1e641eaa4b431932138dc90de33642e5845e31e1fdfd6" | 31 | SRC_URI[sha256sum] = "5c3bf994bb6d6303bbf1e641eaa4b431932138dc90de33642e5845e31e1fdfd6" |
@@ -82,9 +83,3 @@ do_configure_append () { | |||
82 | 83 | ||
83 | } | 84 | } |
84 | 85 | ||
85 | do_install_append() { | ||
86 | install -d ${D}${sysconfdir}/default/volatiles | ||
87 | install -m 0644 ${WORKDIR}/97_fontconfig ${D}${sysconfdir}/default/volatiles | ||
88 | rmdir ${D}${localstatedir}/cache/fontconfig | ||
89 | rmdir ${D}${localstatedir}/cache/ | ||
90 | } | ||