EFL 1.7 svn doobies
[profile/ivi/efreet.git] / src / tests / efreet_icon_cache_dump.c
1 #ifdef HAVE_CONFIG_H
2 # include <config.h>
3 #endif
4 #include <limits.h>
5 #include <stdio.h>
6 #include <sys/stat.h>
7 #include <sys/mman.h>
8 #include <fcntl.h>
9 #include <unistd.h>
10 #include <errno.h>
11
12 #include <Eina.h>
13 #include <Eet.h>
14 #include <Ecore.h>
15 #include <Ecore_File.h>
16
17 #define EFREET_MODULE_LOG_DOM /* no logging in this file */
18
19 #include "Efreet.h"
20 #include "efreet_private.h"
21 #include "efreet_cache_private.h"
22
23 int verbose = 0;
24
25 static void
26 dump(Efreet_Icon_Theme *theme)
27 {
28     Eet_File *ef;
29     unsigned int count = 0;
30     double start, avg;
31     char **keys;
32     int num, i;
33
34     start = ecore_time_get();
35     ef = eet_open(efreet_icon_cache_file(theme->name.internal), EET_FILE_MODE_READ);
36     printf("open: %s %f\n", theme->name.internal, ecore_time_get() - start);
37
38     start = ecore_time_get();
39     keys = eet_list(ef, "*", &num);
40     printf("list: %s %f\n", theme->name.internal, ecore_time_get() - start);
41     if (!keys) return;
42
43     start = ecore_time_get();
44     for (i = 0; i < num; i++)
45     {
46         Efreet_Cache_Icon *icon;
47         unsigned int j;
48
49         icon = eet_data_read(ef, efreet_icon_edd(), keys[i]);
50         if (!icon) continue;
51
52         for (j = 0; j < icon->icons_count; ++j)
53             count += icon->icons[j]->paths_count;
54     }
55     free(keys);
56
57     start = ecore_time_get() - start;
58     avg = start / count;
59     printf("read: %s - %u paths (time: %f) (avg %f)\n", theme->name.internal, count, start, avg);
60     eet_close(ef);
61     eet_clearcache();
62 }
63
64 int
65 main(int argc, char **argv)
66 {
67     Eet_File *theme_ef;
68     Eina_List *l = NULL;
69     Efreet_Icon_Theme *theme;
70     int i;
71
72     efreet_cache_update = 0;
73
74     if (!efreet_init()) return -1;
75
76     theme_ef = eet_open(efreet_icon_theme_cache_file(), EET_FILE_MODE_READ);
77     if (!theme_ef) return -1;
78
79     if (argc > 1)
80     {
81         for (i = 1; i < argc; i++)
82         {
83             theme = eet_data_read(theme_ef, efreet_icon_theme_edd(EINA_FALSE), argv[i]);
84             if (theme) l = eina_list_append(l, theme);
85         }
86     }
87     else
88     {
89         char **keys;
90         int num;
91
92         keys = eet_list(theme_ef, "*", &num);
93         if (keys)
94         {
95             for (i = 0; i < num; i++)
96             {
97                 theme = eet_data_read(theme_ef, efreet_icon_theme_edd(EINA_FALSE), keys[i]);
98                 if (theme) l = eina_list_append(l, theme);
99             }
100             free(keys);
101         }
102     }
103
104     EINA_LIST_FREE(l, theme)
105     {
106         void *data;
107
108         dump(theme);
109
110         /* free theme */
111         eina_list_free(theme->paths);
112         eina_list_free(theme->inherits);
113         EINA_LIST_FREE(theme->directories, data)
114             free(data);
115         free(theme);
116     }
117
118     efreet_shutdown();
119     return 0;
120 }