+ struct icon_context ctx[2];
+ ctx[0] = action_icon_context;
+ ctx[1] = category_icon_context;
+ for (c = 0 ; c < 2 ; ++c)
+ {
+ const struct icon_context *ic = &ctx[c];
+ gint i;
+ for (i = 0 ; i < ic->n_icons ; ++i)
+ {
+ gboolean wildcarded = FALSE;
+ GtkIconSet *icon_set = gtk_icon_set_new ();
+ int r;
+ for (r = 0 ; r < sizeof (sizemap) / sizeof (sizemap[0]); ++r)
+ {
+ int s;
+ GtkIconSource *source = gtk_icon_source_new ();
+ gchar *filename = g_strdup_printf ("%s/%s/%dx%d/%s.png", PKGDATADIR,
+ ic->context_name,
+ sizemap[r].resolution, sizemap[r].resolution,
+ ic->icon_name[i]);
+ const char *relocated_filename = relocate (filename);
+ GFile *gf = g_file_new_for_path (relocated_filename);
+ if (g_file_query_exists (gf, NULL))
+ {
+ gtk_icon_source_set_filename (source, relocated_filename);
+ if (!wildcarded)
+ {
+ gtk_icon_source_set_size_wildcarded (source, TRUE);
+ wildcarded = TRUE;
+ }
+ }
+ g_object_unref (gf);
+
+ for (s = 0 ; s < sizemap[r].n_sizes ; ++s)
+ gtk_icon_source_set_size (source, sizemap[r].usage[s]);
+ if (filename != relocated_filename)
+ free (CONST_CAST (char *, relocated_filename));
+ g_free (filename);
+
+ if ( gtk_icon_source_get_filename (source))
+ gtk_icon_set_add_source (icon_set, source);
+ }
+
+ gtk_icon_factory_add (factory, ic->icon_name[i], icon_set);
+ }
+ }