summaryrefslogtreecommitdiff
path: root/fc-cache
diff options
context:
space:
mode:
authorMike FABIAN <mfabian@suse.de>2006-10-27 10:26:50 -0700
committerKeith Packard <keithp@neko.keithp.com>2006-10-27 10:26:50 -0700
commit0334e5a294dd6a36c94936f6c9c709e86773cf64 (patch)
tree784a344fdf8cc7bdb397505c2ff57dd9c87f08da /fc-cache
parent0596d7296c94b2bb9817338b8c1a76da91673fb9 (diff)
Do not clean cache files for different architectures
Use filenames to clean cache files for current architecture only. This is sufficient as cache files live in their own directory where filenames are under fontconfig control.
Diffstat (limited to 'fc-cache')
-rw-r--r--fc-cache/fc-cache.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/fc-cache/fc-cache.c b/fc-cache/fc-cache.c
index bda8b14..acaa8ba 100644
--- a/fc-cache/fc-cache.c
+++ b/fc-cache/fc-cache.c
@@ -22,6 +22,8 @@
* PERFORMANCE OF THIS SOFTWARE.
*/
+#include "../fc-arch/fcarch.h"
+
#ifdef HAVE_CONFIG_H
#include <config.h>
#else
@@ -40,6 +42,7 @@
#include <errno.h>
#include <fcntl.h>
#include <dirent.h>
+#include <string.h>
#if defined (_WIN32)
#define STRICT
@@ -296,6 +299,12 @@ cleanCacheDirectory (FcConfig *config, FcChar8 *dir, FcBool verbose)
if (ent->d_name[0] == '.')
continue;
+ /* skip cache files for different architectures and */
+ /* files which are not cache files at all */
+ if (strlen(ent->d_name) != 32 + strlen ("-" FC_ARCHITECTURE FC_CACHE_SUFFIX) ||
+ strcmp(ent->d_name + 32, "-" FC_ARCHITECTURE FC_CACHE_SUFFIX))
+ continue;
+
file_name = FcStrPlus (dir_base, (FcChar8 *) ent->d_name);
if (!file_name)
{