comparison src/xs_glade.c @ 814:9d0dee765a8e

Add Glade-generated files, as Glade for Gtk+1 is somewhat troublesome to get compiled and working nowadays due to bitrot.
author Matti Hamalainen <ccr@tnsp.org>
date Wed, 07 Nov 2012 13:10:34 +0200
parents
children
comparison
equal deleted inserted replaced
813:b8b9da405e8c 814:9d0dee765a8e
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
14 #include <gtk/gtk.h>
15
16 #include "xs_glade.h"
17
18 /* This is an internally used function to check if a pixmap file exists. */
19 static gchar* check_file_exists (const gchar *directory,
20 const gchar *filename);
21
22 /* This is an internally used function to create pixmaps. */
23 static GtkWidget* create_dummy_pixmap (GtkWidget *widget);
24
25 GtkWidget*
26 lookup_widget (GtkWidget *widget,
27 const gchar *widget_name)
28 {
29 GtkWidget *parent, *found_widget;
30
31 for (;;)
32 {
33 if (GTK_IS_MENU (widget))
34 parent = gtk_menu_get_attach_widget (GTK_MENU (widget));
35 else
36 parent = widget->parent;
37 if (parent == NULL)
38 break;
39 widget = parent;
40 }
41
42 found_widget = (GtkWidget*) gtk_object_get_data (GTK_OBJECT (widget),
43 widget_name);
44 if (!found_widget)
45 g_warning ("Widget not found: %s", widget_name);
46 return found_widget;
47 }
48
49 /* This is a dummy pixmap we use when a pixmap can't be found. */
50 static char *dummy_pixmap_xpm[] = {
51 /* columns rows colors chars-per-pixel */
52 "1 1 1 1",
53 " c None",
54 /* pixels */
55 " "
56 };
57
58 /* This is an internally used function to create pixmaps. */
59 static GtkWidget*
60 create_dummy_pixmap (GtkWidget *widget)
61 {
62 GdkColormap *colormap;
63 GdkPixmap *gdkpixmap;
64 GdkBitmap *mask;
65 GtkWidget *pixmap;
66
67 colormap = gtk_widget_get_colormap (widget);
68 gdkpixmap = gdk_pixmap_colormap_create_from_xpm_d (NULL, colormap, &mask,
69 NULL, dummy_pixmap_xpm);
70 if (gdkpixmap == NULL)
71 g_error ("Couldn't create replacement pixmap.");
72 pixmap = gtk_pixmap_new (gdkpixmap, mask);
73 gdk_pixmap_unref (gdkpixmap);
74 gdk_bitmap_unref (mask);
75 return pixmap;
76 }
77
78 static GList *pixmaps_directories = NULL;
79
80 /* Use this function to set the directory containing installed pixmaps. */
81 void
82 add_pixmap_directory (const gchar *directory)
83 {
84 pixmaps_directories = g_list_prepend (pixmaps_directories,
85 g_strdup (directory));
86 }
87
88 /* This is an internally used function to create pixmaps. */
89 GtkWidget*
90 create_pixmap (GtkWidget *widget,
91 const gchar *filename)
92 {
93 gchar *found_filename = NULL;
94 GdkColormap *colormap;
95 GdkPixmap *gdkpixmap;
96 GdkBitmap *mask;
97 GtkWidget *pixmap;
98 GList *elem;
99
100 if (!filename || !filename[0])
101 return create_dummy_pixmap (widget);
102
103 /* We first try any pixmaps directories set by the application. */
104 elem = pixmaps_directories;
105 while (elem)
106 {
107 found_filename = check_file_exists ((gchar*)elem->data, filename);
108 if (found_filename)
109 break;
110 elem = elem->next;
111 }
112
113 /* If we haven't found the pixmap, try the source directory. */
114 if (!found_filename)
115 {
116 found_filename = check_file_exists ("../pixmaps", filename);
117 }
118
119 if (!found_filename)
120 {
121 g_warning (_("Couldn't find pixmap file: %s"), filename);
122 return create_dummy_pixmap (widget);
123 }
124
125 colormap = gtk_widget_get_colormap (widget);
126 gdkpixmap = gdk_pixmap_colormap_create_from_xpm (NULL, colormap, &mask,
127 NULL, found_filename);
128 if (gdkpixmap == NULL)
129 {
130 g_warning (_("Error loading pixmap file: %s"), found_filename);
131 g_free (found_filename);
132 return create_dummy_pixmap (widget);
133 }
134 g_free (found_filename);
135 pixmap = gtk_pixmap_new (gdkpixmap, mask);
136 gdk_pixmap_unref (gdkpixmap);
137 gdk_bitmap_unref (mask);
138 return pixmap;
139 }
140
141 /* This is an internally used function to check if a pixmap file exists. */
142 static gchar*
143 check_file_exists (const gchar *directory,
144 const gchar *filename)
145 {
146 gchar *full_filename;
147 struct stat s;
148 gint status;
149
150 full_filename = (gchar*) g_malloc (strlen (directory) + 1
151 + strlen (filename) + 1);
152 strcpy (full_filename, directory);
153 strcat (full_filename, G_DIR_SEPARATOR_S);
154 strcat (full_filename, filename);
155
156 status = stat (full_filename, &s);
157 if (status == 0 && S_ISREG (s.st_mode))
158 return full_filename;
159 g_free (full_filename);
160 return NULL;
161 }
162