rename StgSync to SpinLock
[ghc-hetmet.git] / rts / VisSupport.c
1 /*
2  * DO NOT EDIT THIS FILE - it is generated by Glade.
3  */
4
5 #ifdef HAVE_CONFIG_H
6 #  include <config.h>
7 #endif
8
9 #include <sys/types.h>
10 #include <sys/stat.h>
11 #include <unistd.h>
12 #include <string.h>
13 #include <stdio.h>
14
15 #include <gtk/gtk.h>
16
17 #include "VisSupport.h"
18
19 GtkWidget*
20 lookup_widget                          (GtkWidget       *widget,
21                                         const gchar     *widget_name)
22 {
23   GtkWidget *parent, *found_widget;
24
25   for (;;)
26     {
27       if (GTK_IS_MENU (widget))
28         parent = gtk_menu_get_attach_widget (GTK_MENU (widget));
29       else
30         parent = widget->parent;
31       if (!parent)
32         parent = (GtkWidget*) g_object_get_data (G_OBJECT (widget), "GladeParentKey");
33       if (parent == NULL)
34         break;
35       widget = parent;
36     }
37
38   found_widget = (GtkWidget*) g_object_get_data (G_OBJECT (widget),
39                                                  widget_name);
40   if (!found_widget)
41     g_warning ("Widget not found: %s", widget_name);
42   return found_widget;
43 }
44
45 static GList *pixmaps_directories = NULL;
46
47 /* Use this function to set the directory containing installed pixmaps. */
48 void
49 add_pixmap_directory                   (const gchar     *directory)
50 {
51   pixmaps_directories = g_list_prepend (pixmaps_directories,
52                                         g_strdup (directory));
53 }
54
55 /* This is an internally used function to find pixmap files. */
56 static gchar*
57 find_pixmap_file                       (const gchar     *filename)
58 {
59   GList *elem;
60
61   /* We step through each of the pixmaps directory to find it. */
62   elem = pixmaps_directories;
63   while (elem)
64     {
65       gchar *pathname = g_strdup_printf ("%s%s%s", (gchar*)elem->data,
66                                          G_DIR_SEPARATOR_S, filename);
67       if (g_file_test (pathname, G_FILE_TEST_EXISTS))
68         return pathname;
69       g_free (pathname);
70       elem = elem->next;
71     }
72   return NULL;
73 }
74
75 /* This is an internally used function to create pixmaps. */
76 GtkWidget*
77 create_pixmap                          (GtkWidget       *widget,
78                                         const gchar     *filename)
79 {
80   gchar *pathname = NULL;
81   GtkWidget *pixmap;
82
83   if (!filename || !filename[0])
84       return gtk_image_new ();
85
86   pathname = find_pixmap_file (filename);
87
88   if (!pathname)
89     {
90       g_warning ("Couldn't find pixmap file: %s", filename);
91       return gtk_image_new ();
92     }
93
94   pixmap = gtk_image_new_from_file (pathname);
95   g_free (pathname);
96   return pixmap;
97 }
98
99 /* This is an internally used function to create pixmaps. */
100 GdkPixbuf*
101 create_pixbuf                          (const gchar     *filename)
102 {
103   gchar *pathname = NULL;
104   GdkPixbuf *pixbuf;
105   GError *error = NULL;
106
107   if (!filename || !filename[0])
108       return NULL;
109
110   pathname = find_pixmap_file (filename);
111
112   if (!pathname)
113     {
114       g_warning ("Couldn't find pixmap file: %s", filename);
115       return NULL;
116     }
117
118   pixbuf = gdk_pixbuf_new_from_file (pathname, &error);
119   if (!pixbuf)
120     {
121       fprintf (stderr, "Failed to load pixbuf file: %s: %s\n",
122                pathname, error->message);
123       g_error_free (error);
124     }
125   g_free (pathname);
126   return pixbuf;
127 }
128
129 /* This is used to set ATK action descriptions. */
130 void
131 glade_set_atk_action_description       (AtkAction       *action,
132                                         const gchar     *action_name,
133                                         const gchar     *description)
134 {
135   gint n_actions, i;
136
137   n_actions = atk_action_get_n_actions (action);
138   for (i = 0; i < n_actions; i++)
139     {
140       if (!strcmp (atk_action_get_name (action, i), action_name))
141         atk_action_set_description (action, i, description);
142     }
143 }
144