aboutsummaryrefslogtreecommitdiffstats
path: root/lib/widgets/ephy-spinner.c
diff options
context:
space:
mode:
Diffstat (limited to 'lib/widgets/ephy-spinner.c')
-rw-r--r--lib/widgets/ephy-spinner.c131
1 files changed, 84 insertions, 47 deletions
diff --git a/lib/widgets/ephy-spinner.c b/lib/widgets/ephy-spinner.c
index 0aae90bf5..2e3b17327 100644
--- a/lib/widgets/ephy-spinner.c
+++ b/lib/widgets/ephy-spinner.c
@@ -27,7 +27,7 @@
*/
#ifdef HAVE_CONFIG_H
-#include <config.h>
+#include "config.h"
#endif
#include "ephy-spinner.h"
@@ -39,7 +39,8 @@
#define EPHY_SPINNER_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), EPHY_TYPE_SPINNER, EphySpinnerDetails))
-struct EphySpinnerDetails {
+struct EphySpinnerDetails
+{
GList *image_list;
GdkPixbuf *quiescent_pixbuf;
GtkIconTheme *icon_theme;
@@ -53,22 +54,22 @@ struct EphySpinnerDetails {
gboolean small_mode;
};
-static void ephy_spinner_class_init (EphySpinnerClass *class);
-static void ephy_spinner_init (EphySpinner *spinner);
-static void ephy_spinner_load_images (EphySpinner *spinner);
-static void ephy_spinner_unload_images (EphySpinner *spinner);
-static void ephy_spinner_remove_update_callback (EphySpinner *spinner);
-static void ephy_spinner_theme_changed (GtkIconTheme *icon_theme,
- EphySpinner *spinner);
+static void ephy_spinner_class_init (EphySpinnerClass *class);
+static void ephy_spinner_init (EphySpinner *spinner);
+static void ephy_spinner_load_images (EphySpinner *spinner);
+static void ephy_spinner_unload_images (EphySpinner *spinner);
+static void ephy_spinner_remove_update_callback (EphySpinner *spinner);
+static void ephy_spinner_theme_changed (GtkIconTheme *icon_theme,
+ EphySpinner *spinner);
static GObjectClass *parent_class = NULL;
GType
ephy_spinner_get_type (void)
{
- static GType ephy_spinner_type = 0;
+ static GType type = 0;
- if (ephy_spinner_type == 0)
+ if (type == 0)
{
static const GTypeInfo our_info =
{
@@ -83,13 +84,12 @@ ephy_spinner_get_type (void)
(GInstanceInitFunc) ephy_spinner_init
};
- ephy_spinner_type = g_type_register_static (GTK_TYPE_EVENT_BOX,
- "EphySpinner",
- &our_info, 0);
+ type = g_type_register_static (GTK_TYPE_EVENT_BOX,
+ "EphySpinner",
+ &our_info, 0);
}
- return ephy_spinner_type;
-
+ return type;
}
/*
@@ -104,11 +104,7 @@ ephy_spinner_get_type (void)
GtkWidget *
ephy_spinner_new (void)
{
- GtkWidget *s;
-
- s = GTK_WIDGET (g_object_new (EPHY_TYPE_SPINNER, NULL));
-
- return s;
+ return GTK_WIDGET (g_object_new (EPHY_TYPE_SPINNER, NULL));
}
static gboolean
@@ -138,16 +134,19 @@ get_spinner_dimensions (EphySpinner *spinner, int *spinner_width, int* spinner_h
/* loop through all the installed images, taking the union */
image_list = spinner->details->image_list;
- while (image_list != NULL) {
+ while (image_list != NULL)
+ {
pixbuf = GDK_PIXBUF (image_list->data);
pixbuf_width = gdk_pixbuf_get_width (pixbuf);
pixbuf_height = gdk_pixbuf_get_height (pixbuf);
- if (pixbuf_width > current_width) {
+ if (pixbuf_width > current_width)
+ {
current_width = pixbuf_width;
}
- if (pixbuf_height > current_height) {
+ if (pixbuf_height > current_height)
+ {
current_height = pixbuf_height;
}
@@ -174,12 +173,19 @@ ephy_spinner_init (EphySpinner *spinner)
spinner->details = EPHY_SPINNER_GET_PRIVATE (spinner);
spinner->details->delay = spinner_DEFAULT_TIMEOUT;
+ /* FIXME: icon theme is per-screen, not global */
spinner->details->icon_theme = gtk_icon_theme_get_default ();
g_signal_connect (spinner->details->icon_theme,
"changed",
G_CALLBACK (ephy_spinner_theme_changed),
spinner);
+ spinner->details->quiescent_pixbuf = NULL;
+ spinner->details->image_list = NULL;
+ spinner->details->max_frame = 0;
+ spinner->details->current_frame = 0;
+ spinner->details->timer_task = 0;
+
ephy_spinner_load_images (spinner);
gtk_widget_show (widget);
}
@@ -201,19 +207,25 @@ select_spinner_image (EphySpinner *spinner)
{
GList *element;
- if (spinner->details->timer_task == 0) {
- if (spinner->details->quiescent_pixbuf) {
+ if (spinner->details->timer_task == 0)
+ {
+ if (spinner->details->quiescent_pixbuf)
+ {
return g_object_ref (spinner->details->quiescent_pixbuf);
- } else {
+ }
+ else
+ {
return NULL;
}
}
- if (spinner->details->image_list == NULL) {
+ if (spinner->details->image_list == NULL)
+ {
return NULL;
}
element = g_list_nth (spinner->details->image_list, spinner->details->current_frame);
+ g_return_val_if_fail (element != NULL, NULL);
return g_object_ref (element->data);
}
@@ -236,7 +248,8 @@ ephy_spinner_expose (GtkWidget *widget, GdkEventExpose *event)
if (!GTK_WIDGET_DRAWABLE (spinner)) return TRUE;
pixbuf = select_spinner_image (spinner);
- if (pixbuf == NULL) {
+ if (pixbuf == NULL)
+ {
return FALSE;
}
@@ -252,7 +265,8 @@ ephy_spinner_expose (GtkWidget *widget, GdkEventExpose *event)
pix_area.width = width;
pix_area.height = height;
- if (!gdk_rectangle_intersect (&event->area, &pix_area, &dest)) {
+ if (!gdk_rectangle_intersect (&event->area, &pix_area, &dest))
+ {
g_object_unref (pixbuf);
return FALSE;
}
@@ -279,10 +293,14 @@ bump_spinner_frame (gpointer callback_data)
spinner = EPHY_SPINNER (callback_data);
- if (!GTK_WIDGET_DRAWABLE (spinner)) return TRUE;
+ if (!GTK_WIDGET_DRAWABLE (spinner))
+ {
+ return TRUE;
+ }
spinner->details->current_frame += 1;
- if (spinner->details->current_frame > spinner->details->max_frame - 1) {
+ if (spinner->details->current_frame > spinner->details->max_frame - 1)
+ {
spinner->details->current_frame = 0;
}
@@ -299,11 +317,13 @@ bump_spinner_frame (gpointer callback_data)
void
ephy_spinner_start (EphySpinner *spinner)
{
- if (is_throbbing (spinner)) {
+ if (is_throbbing (spinner))
+ {
return;
}
- if (spinner->details->timer_task != 0) {
+ if (spinner->details->timer_task != 0)
+ {
g_source_remove (spinner->details->timer_task);
}
@@ -317,7 +337,8 @@ ephy_spinner_start (EphySpinner *spinner)
static void
ephy_spinner_remove_update_callback (EphySpinner *spinner)
{
- if (spinner->details->timer_task != 0) {
+ if (spinner->details->timer_task != 0)
+ {
g_source_remove (spinner->details->timer_task);
}
@@ -333,7 +354,8 @@ ephy_spinner_remove_update_callback (EphySpinner *spinner)
void
ephy_spinner_stop (EphySpinner *spinner)
{
- if (!is_throbbing (spinner)) {
+ if (!is_throbbing (spinner))
+ {
return;
}
@@ -351,20 +373,24 @@ ephy_spinner_unload_images (EphySpinner *spinner)
{
GList *current_entry;
- if (spinner->details->quiescent_pixbuf != NULL) {
+ if (spinner->details->quiescent_pixbuf != NULL)
+ {
g_object_unref (spinner->details->quiescent_pixbuf);
spinner->details->quiescent_pixbuf = NULL;
}
/* unref all the images in the list, and then let go of the list itself */
current_entry = spinner->details->image_list;
- while (current_entry != NULL) {
+ while (current_entry != NULL)
+ {
g_object_unref (current_entry->data);
current_entry = current_entry->next;
}
g_list_free (spinner->details->image_list);
spinner->details->image_list = NULL;
+
+ spinner->details->current_frame = 0;
}
static GdkPixbuf *
@@ -375,12 +401,15 @@ scale_to_real_size (EphySpinner *spinner, GdkPixbuf *pixbuf)
size = gdk_pixbuf_get_height (pixbuf);
- if (spinner->details->small_mode) {
+ if (spinner->details->small_mode)
+ {
result = gdk_pixbuf_scale_simple (pixbuf,
size * 2 / 3,
size * 2 / 3,
GDK_INTERP_BILINEAR);
- } else {
+ }
+ else
+ {
result = g_object_ref (pixbuf);
}
@@ -393,7 +422,8 @@ extract_frame (EphySpinner *spinner, GdkPixbuf *grid_pixbuf, int x, int y, int s
GdkPixbuf *pixbuf, *result;
if (x + size > gdk_pixbuf_get_width (grid_pixbuf) ||
- y + size > gdk_pixbuf_get_height (grid_pixbuf)) {
+ y + size > gdk_pixbuf_get_height (grid_pixbuf))
+ {
return NULL;
}
@@ -423,22 +453,25 @@ ephy_spinner_load_images (EphySpinner *spinner)
/* Load the animation */
icon_info = gtk_icon_theme_lookup_icon (spinner->details->icon_theme,
"gnome-spinner", -1, 0);
- if (icon_info == NULL) {
+ if (icon_info == NULL)
+ {
g_warning ("Throbber animation not found");
return;
}
size = gtk_icon_info_get_base_size (icon_info);
icon = gtk_icon_info_get_filename (icon_info);
- g_return_if_fail (icon_info != NULL);
+ g_return_if_fail (icon != NULL);
icon_pixbuf = gdk_pixbuf_new_from_file (icon, NULL);
grid_width = gdk_pixbuf_get_width (icon_pixbuf);
grid_height = gdk_pixbuf_get_height (icon_pixbuf);
image_list = NULL;
- for (y = 0; y < grid_height; y += size) {
- for (x = 0; x < grid_width ; x += size) {
+ for (y = 0; y < grid_height; y += size)
+ {
+ for (x = 0; x < grid_width ; x += size)
+ {
pixbuf = extract_frame (spinner, icon_pixbuf, x, y, size);
if (pixbuf)
@@ -460,13 +493,16 @@ ephy_spinner_load_images (EphySpinner *spinner)
/* Load the rest icon */
icon_info = gtk_icon_theme_lookup_icon (spinner->details->icon_theme,
"gnome-spinner-rest", -1, 0);
- if (icon == NULL) {
+ if (icon_info == NULL)
+ {
g_warning ("Throbber rest icon not found");
return;
}
size = gtk_icon_info_get_base_size (icon_info);
icon = gtk_icon_info_get_filename (icon_info);
+ g_return_if_fail (icon != NULL);
+
icon_pixbuf = gdk_pixbuf_new_from_file (icon, NULL);
spinner->details->quiescent_pixbuf = scale_to_real_size (spinner, icon_pixbuf);
@@ -485,7 +521,8 @@ ephy_spinner_load_images (EphySpinner *spinner)
void
ephy_spinner_set_small_mode (EphySpinner *spinner, gboolean new_mode)
{
- if (new_mode != spinner->details->small_mode) {
+ if (new_mode != spinner->details->small_mode)
+ {
spinner->details->small_mode = new_mode;
ephy_spinner_load_images (spinner);