aboutsummaryrefslogtreecommitdiffstats
path: root/widgets/misc
diff options
context:
space:
mode:
authorMatthew Barnes <mbarnes@redhat.com>2010-03-03 02:13:56 +0800
committerMatthew Barnes <mbarnes@redhat.com>2010-04-08 22:24:08 +0800
commit3ba0b61f9f447b01c3a83bfb78ee33a45d413700 (patch)
tree1a2d2f3ee35c2d1688971278aee53e2a112a2d8e /widgets/misc
parentf585bf4b61434414feef95711feb7d53213e1098 (diff)
downloadgsoc2013-evolution-3ba0b61f9f447b01c3a83bfb78ee33a45d413700.tar
gsoc2013-evolution-3ba0b61f9f447b01c3a83bfb78ee33a45d413700.tar.gz
gsoc2013-evolution-3ba0b61f9f447b01c3a83bfb78ee33a45d413700.tar.bz2
gsoc2013-evolution-3ba0b61f9f447b01c3a83bfb78ee33a45d413700.tar.lz
gsoc2013-evolution-3ba0b61f9f447b01c3a83bfb78ee33a45d413700.tar.xz
gsoc2013-evolution-3ba0b61f9f447b01c3a83bfb78ee33a45d413700.tar.zst
gsoc2013-evolution-3ba0b61f9f447b01c3a83bfb78ee33a45d413700.zip
Replace ESpinner with GtkSpinner.
Also, bump our GTK+ requirement to 2.20.
Diffstat (limited to 'widgets/misc')
-rw-r--r--widgets/misc/Makefile.am2
-rw-r--r--widgets/misc/e-activity-proxy.c5
-rw-r--r--widgets/misc/e-spinner.c992
-rw-r--r--widgets/misc/e-spinner.h39
4 files changed, 2 insertions, 1036 deletions
diff --git a/widgets/misc/Makefile.am b/widgets/misc/Makefile.am
index dceaab45ee..9a33f48b32 100644
--- a/widgets/misc/Makefile.am
+++ b/widgets/misc/Makefile.am
@@ -69,8 +69,6 @@ widgetsinclude_HEADERS = \
e-signature-preview.h \
e-signature-script-dialog.h \
e-signature-tree-view.h \
- e-spinner.c \
- e-spinner.h \
e-url-entry.h \
e-web-view.h \
ea-calendar-cell.h \
diff --git a/widgets/misc/e-activity-proxy.c b/widgets/misc/e-activity-proxy.c
index 10249b1911..825aae04d6 100644
--- a/widgets/misc/e-activity-proxy.c
+++ b/widgets/misc/e-activity-proxy.c
@@ -22,7 +22,6 @@
#include "e-activity-proxy.h"
#include <glib/gi18n.h>
-#include <e-spinner.h>
#define E_ACTIVITY_PROXY_GET_PRIVATE(obj) \
(G_TYPE_INSTANCE_GET_PRIVATE \
@@ -277,8 +276,8 @@ activity_proxy_init (EActivityProxy *proxy)
proxy->priv->button = g_object_ref (widget);
gtk_widget_hide (widget);
- /* XXX What's the rationale for killing the old spinner API? */
- widget = e_spinner_new_spinning_small_shown ();
+ widget = gtk_spinner_new ();
+ gtk_spinner_start (GTK_SPINNER (widget));
gtk_box_pack_start (GTK_BOX (container), widget, FALSE, FALSE, 0);
proxy->priv->spinner = g_object_ref (widget);
gtk_widget_show (widget);
diff --git a/widgets/misc/e-spinner.c b/widgets/misc/e-spinner.c
deleted file mode 100644
index 5e7833b34f..0000000000
--- a/widgets/misc/e-spinner.c
+++ /dev/null
@@ -1,992 +0,0 @@
-/*
- * Copyright © 2000 Eazel, Inc.
- * Copyright © 2002-2004 Marco Pesenti Gritti
- * Copyright © 2004, 2006 Christian Persch
- *
- * Nautilus is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * Nautilus is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
- *
- * Author: Andy Hertzfeld <andy@eazel.com>
- *
- * Ephy port by Marco Pesenti Gritti <marco@it.gnome.org>
- *
- * $Id: e-spinner.c 12639 2006-12-12 17:06:55Z chpe $
- */
-
-/*
- * From Nautilus ephy-spinner.c
- */
-
-#include "config.h"
-
-#include "e-spinner.h"
-
-#define E_TYPE_SPINNER (e_spinner_get_type ())
-#define E_SPINNER(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), E_TYPE_SPINNER, ESpinner))
-#define E_SPINNER_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), E_TYPE_SPINNER, ESpinnerClass))
-#define E_IS_SPINNER(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), E_TYPE_SPINNER))
-#define E_IS_SPINNER_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), E_TYPE_SPINNER))
-#define E_SPINNER_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), E_TYPE_SPINNER, ESpinnerClass))
-
-typedef struct _ESpinner ESpinner;
-typedef struct _ESpinnerClass ESpinnerClass;
-typedef struct _ESpinnerDetails ESpinnerDetails;
-
-struct _ESpinner
-{
- GtkWidget parent;
-
- /*< private >*/
- ESpinnerDetails *details;
-};
-
-struct _ESpinnerClass
-{
- GtkWidgetClass parent_class;
-};
-
-#define LOG(msg, args...)
-#define START_PROFILER(name)
-#define STOP_PROFILER(name)
-
-#include "e-util/e-icon-factory.h"
-
-/* Spinner cache implementation */
-
-#define E_TYPE_SPINNER_CACHE (e_spinner_cache_get_type())
-#define E_SPINNER_CACHE(object) (G_TYPE_CHECK_INSTANCE_CAST((object), E_TYPE_SPINNER_CACHE, ESpinnerCache))
-#define E_SPINNER_CACHE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass), E_TYPE_SPINNER_CACHE, ESpinnerCacheClass))
-#define E_IS_SPINNER_CACHE(object) (G_TYPE_CHECK_INSTANCE_TYPE((object), E_TYPE_SPINNER_CACHE))
-#define E_IS_SPINNER_CACHE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), E_TYPE_SPINNER_CACHE))
-#define E_SPINNER_CACHE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj), E_TYPE_SPINNER_CACHE, ESpinnerCacheClass))
-
-typedef struct _ESpinnerCache ESpinnerCache;
-typedef struct _ESpinnerCacheClass ESpinnerCacheClass;
-typedef struct _ESpinnerCachePrivate ESpinnerCachePrivate;
-
-struct _ESpinnerCacheClass
-{
- GObjectClass parent_class;
-};
-
-struct _ESpinnerCache
-{
- GObject parent_object;
-
- /*< private >*/
- ESpinnerCachePrivate *priv;
-};
-
-#define E_SPINNER_CACHE_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), E_TYPE_SPINNER_CACHE, ESpinnerCachePrivate))
-
-struct _ESpinnerCachePrivate
-{
- /* Hash table of GdkScreen -> ESpinnerCacheData */
- GHashTable *hash;
-};
-
-typedef struct
-{
- guint ref_count;
- GtkIconSize size;
- gint width;
- gint height;
- GdkPixbuf **animation_pixbufs;
- guint n_animation_pixbufs;
-} ESpinnerImages;
-
-#define LAST_ICON_SIZE GTK_ICON_SIZE_DIALOG + 1
-#define SPINNER_ICON_NAME "process-working"
-#define SPINNER_FALLBACK_ICON_NAME "gnome-spinner"
-#define E_SPINNER_IMAGES_INVALID ((ESpinnerImages *) 0x1)
-
-typedef struct
-{
- GdkScreen *screen;
- GtkIconTheme *icon_theme;
- ESpinnerImages *images[LAST_ICON_SIZE];
-} ESpinnerCacheData;
-
-static void e_spinner_cache_class_init (ESpinnerCacheClass *klass);
-static void e_spinner_cache_init (ESpinnerCache *cache);
-
-static GObjectClass *e_spinner_cache_parent_class;
-static gpointer spinner_cache = NULL;
-
-static GType
-e_spinner_cache_get_type (void)
-{
- static GType type = 0;
-
- if (G_UNLIKELY (type == 0))
- {
- const GTypeInfo our_info =
- {
- sizeof (ESpinnerCacheClass),
- NULL,
- NULL,
- (GClassInitFunc) e_spinner_cache_class_init,
- NULL,
- NULL,
- sizeof (ESpinnerCache),
- 0,
- (GInstanceInitFunc) e_spinner_cache_init
- };
-
- type = g_type_register_static (G_TYPE_OBJECT,
- "ESpinnerCache",
- &our_info, 0);
- }
-
- return type;
-}
-
-static ESpinnerImages *
-e_spinner_images_ref (ESpinnerImages *images)
-{
- g_return_val_if_fail (images != NULL, NULL);
-
- images->ref_count++;
-
- return images;
-}
-
-static void
-e_spinner_images_unref (ESpinnerImages *images)
-{
- g_return_if_fail (images != NULL);
-
- images->ref_count--;
- if (images->ref_count == 0)
- {
- guint i;
-
- LOG ("Freeing spinner images %p for size %d", images, images->size);
-
- for (i = 0; i < images->n_animation_pixbufs; ++i)
- {
- g_object_unref (images->animation_pixbufs[i]);
- }
- g_free (images->animation_pixbufs);
-
- g_free (images);
- }
-}
-
-static void
-e_spinner_cache_data_unload (ESpinnerCacheData *data)
-{
- GtkIconSize size;
- ESpinnerImages *images;
-
- g_return_if_fail (data != NULL);
-
- LOG ("ESpinnerDataCache unload for screen %p", data->screen);
-
- for (size = GTK_ICON_SIZE_INVALID; size < LAST_ICON_SIZE; ++size)
- {
- images = data->images[size];
- data->images[size] = NULL;
-
- if (images != NULL && images != E_SPINNER_IMAGES_INVALID)
- {
- e_spinner_images_unref (images);
- }
- }
-}
-
-static GdkPixbuf *
-extract_frame (GdkPixbuf *grid_pixbuf,
- gint x,
- gint y,
- gint size)
-{
- GdkPixbuf *pixbuf;
-
- if (x + size > gdk_pixbuf_get_width (grid_pixbuf) ||
- y + size > gdk_pixbuf_get_height (grid_pixbuf))
- {
- return NULL;
- }
-
- pixbuf = gdk_pixbuf_new_subpixbuf (grid_pixbuf,
- x, y,
- size, size);
- g_return_val_if_fail (pixbuf != NULL, NULL);
-
- return pixbuf;
-}
-
-static GdkPixbuf *
-scale_to_size (GdkPixbuf *pixbuf,
- gint dw,
- gint dh)
-{
- GdkPixbuf *result;
- gint pw, ph;
-
- g_return_val_if_fail (pixbuf != NULL, NULL);
-
- pw = gdk_pixbuf_get_width (pixbuf);
- ph = gdk_pixbuf_get_height (pixbuf);
-
- if (pw != dw || ph != dh)
- {
- result = e_icon_factory_pixbuf_scale (pixbuf, dw, dh);
- g_object_unref (pixbuf);
- return result;
- }
-
- return pixbuf;
-}
-
-static ESpinnerImages *
-e_spinner_images_load (GdkScreen *screen,
- GtkIconTheme *icon_theme,
- GtkIconSize icon_size)
-{
- ESpinnerImages *images;
- GdkPixbuf *icon_pixbuf, *pixbuf;
- GtkIconInfo *icon_info = NULL;
- gint grid_width, grid_height, x, y, requested_size, size, isw, ish, n;
- const gchar *icon;
- GSList *list = NULL, *l;
-
- LOG ("ESpinnerCacheData loading for screen %p at size %d", screen, icon_size);
-
- START_PROFILER ("loading spinner animation")
-
- if (!gtk_icon_size_lookup_for_settings (gtk_settings_get_for_screen (screen),
- icon_size, &isw, &ish)) goto loser;
-
- requested_size = MAX (ish, isw);
-
- /* Load the animation. The 'rest icon' is the 0th frame */
- icon_info = gtk_icon_theme_lookup_icon (icon_theme,
- SPINNER_ICON_NAME,
- requested_size, 0);
- if (icon_info == NULL)
- {
- g_warning ("Throbber animation not found");
-
- /* If the icon naming spec compliant name wasn't found, try the old name */
- icon_info = gtk_icon_theme_lookup_icon (icon_theme,
- SPINNER_FALLBACK_ICON_NAME,
- requested_size, 0);
- if (icon_info == NULL)
- {
- g_warning ("Throbber fallback animation not found either");
- goto loser;
- }
- }
- if (icon_info == NULL) {
- g_warning ("icon_info is NULL");
- goto loser;
- }
-
- size = gtk_icon_info_get_base_size (icon_info);
- icon = gtk_icon_info_get_filename (icon_info);
- if (icon == NULL) goto loser;
-
- icon_pixbuf = gdk_pixbuf_new_from_file (icon, NULL);
- gtk_icon_info_free (icon_info);
- icon_info = NULL;
-
- if (icon_pixbuf == NULL)
- {
- g_warning ("Could not load the spinner file");
- goto loser;
- }
-
- grid_width = gdk_pixbuf_get_width (icon_pixbuf);
- grid_height = gdk_pixbuf_get_height (icon_pixbuf);
-
- n = 0;
- for (y = 0; y < grid_height; y += size)
- {
- for (x = 0; x < grid_width; x += size)
- {
- pixbuf = extract_frame (icon_pixbuf, x, y, size);
-
- if (pixbuf)
- {
- list = g_slist_prepend (list, pixbuf);
- ++n;
- }
- else
- {
- g_warning ("Cannot extract frame (%d, %d) from the grid\n", x, y);
- }
- }
- }
-
- g_object_unref (icon_pixbuf);
-
- if (list == NULL || n <= 0) goto loser;
-
- if (size > requested_size)
- {
- for (l = list; l != NULL; l = l->next)
- {
- l->data = scale_to_size (l->data, isw, ish);
- }
- }
-
- /* Now we've successfully got all the data */
- images = g_new (ESpinnerImages, 1);
- images->ref_count = 1;
-
- images->size = icon_size;
- images->width = images->height = requested_size;
-
- images->n_animation_pixbufs = n;
- images->animation_pixbufs = g_new (GdkPixbuf *, n);
-
- for (l = list; l != NULL; l = l->next)
- {
- if (l->data)
- images->animation_pixbufs[--n] = l->data;
- }
- if (n != 0) {
- g_warning ("n != 0 \n");
- }
-
- g_slist_free (list);
-
- STOP_PROFILER ("loading spinner animation")
-
- return images;
-
-loser:
- if (icon_info)
- {
- gtk_icon_info_free (icon_info);
- }
- g_slist_foreach (list, (GFunc) g_object_unref, NULL);
-
- STOP_PROFILER ("loading spinner animation")
-
- return NULL;
-}
-
-static ESpinnerCacheData *
-e_spinner_cache_data_new (GdkScreen *screen)
-{
- ESpinnerCacheData *data;
-
- data = g_new0 (ESpinnerCacheData, 1);
-
- data->screen = screen;
- data->icon_theme = gtk_icon_theme_get_for_screen (screen);
- g_signal_connect_swapped (data->icon_theme, "changed",
- G_CALLBACK (e_spinner_cache_data_unload),
- data);
-
- return data;
-}
-
-static void
-e_spinner_cache_data_free (ESpinnerCacheData *data)
-{
- g_return_if_fail (data != NULL);
- g_return_if_fail (data->icon_theme != NULL);
-
- g_signal_handlers_disconnect_by_func
- (data->icon_theme,
- G_CALLBACK (e_spinner_cache_data_unload), data);
-
- e_spinner_cache_data_unload (data);
-
- g_free (data);
-}
-
-static ESpinnerImages *
-e_spinner_cache_get_images (ESpinnerCache *cache,
- GdkScreen *screen,
- GtkIconSize icon_size)
-{
- ESpinnerCachePrivate *priv = cache->priv;
- ESpinnerCacheData *data;
- ESpinnerImages *images;
-
- LOG ("Getting animation images for screen %p at size %d", screen, icon_size);
-
- g_return_val_if_fail (icon_size < LAST_ICON_SIZE, NULL);
-
- /* Backward compat: "invalid" meant "native" size which doesn't exist anymore */
- if (icon_size == GTK_ICON_SIZE_INVALID)
- {
- icon_size = GTK_ICON_SIZE_DIALOG;
- }
-
- data = g_hash_table_lookup (priv->hash, screen);
- if (data == NULL)
- {
- data = e_spinner_cache_data_new (screen);
- /* FIXME: think about what happens when the screen's display is closed later on */
- g_hash_table_insert (priv->hash, screen, data);
- }
-
- images = data->images[icon_size];
- if (images == E_SPINNER_IMAGES_INVALID)
- {
- /* Load failed, but don't try endlessly again! */
- return NULL;
- }
-
- if (images != NULL)
- {
- /* Return cached data */
- return e_spinner_images_ref (images);
- }
-
- images = e_spinner_images_load (screen, data->icon_theme, icon_size);
-
- if (images == NULL)
- {
- /* Mark as failed-to-load */
- data->images[icon_size] = E_SPINNER_IMAGES_INVALID;
-
- return NULL;
- }
-
- data->images[icon_size] = images;
-
- return e_spinner_images_ref (images);
-}
-
-static void
-e_spinner_cache_init (ESpinnerCache *cache)
-{
- ESpinnerCachePrivate *priv;
-
- priv = cache->priv = E_SPINNER_CACHE_GET_PRIVATE (cache);
-
- LOG ("ESpinnerCache initialising");
-
- priv->hash = g_hash_table_new_full (g_direct_hash, g_direct_equal,
- NULL,
- (GDestroyNotify) e_spinner_cache_data_free);
-}
-
-static void
-e_spinner_cache_finalize (GObject *object)
-{
- ESpinnerCache *cache = E_SPINNER_CACHE (object);
- ESpinnerCachePrivate *priv = cache->priv;
-
- g_hash_table_destroy (priv->hash);
-
- LOG ("ESpinnerCache finalised");
-
- G_OBJECT_CLASS (e_spinner_cache_parent_class)->finalize (object);
-}
-
-static void
-e_spinner_cache_class_init (ESpinnerCacheClass *klass)
-{
- GObjectClass *object_class = G_OBJECT_CLASS (klass);
-
- e_spinner_cache_parent_class = g_type_class_peek_parent (klass);
-
- object_class->finalize = e_spinner_cache_finalize;
-
- g_type_class_add_private (object_class, sizeof (ESpinnerCachePrivate));
-}
-
-static ESpinnerCache *
-e_spinner_cache_ref (void)
-{
- if (G_UNLIKELY (spinner_cache == NULL))
- {
- spinner_cache = g_object_new (E_TYPE_SPINNER_CACHE, NULL);
- g_object_add_weak_pointer (
- G_OBJECT (spinner_cache), &spinner_cache);
- }
-
- return g_object_ref_sink (spinner_cache);
-}
-
-/* Spinner implementation */
-
-#define SPINNER_TIMEOUT 125 /* ms */
-
-#define E_SPINNER_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), E_TYPE_SPINNER, ESpinnerDetails))
-
-struct _ESpinnerDetails
-{
- GtkIconTheme *icon_theme;
- ESpinnerCache *cache;
- GtkIconSize size;
- ESpinnerImages *images;
- guint current_image;
- guint timeout;
- guint timer_task;
- guint spinning : 1;
- guint need_load : 1;
-};
-
-static void e_spinner_class_init (ESpinnerClass *class);
-static void e_spinner_init (ESpinner *spinner);
-
-static GObjectClass *parent_class;
-
-static GType
-e_spinner_get_type (void)
-{
- static GType type = 0;
-
- if (G_UNLIKELY (type == 0))
- {
- const GTypeInfo our_info =
- {
- sizeof (ESpinnerClass),
- NULL, /* base_init */
- NULL, /* base_finalize */
- (GClassInitFunc) e_spinner_class_init,
- NULL,
- NULL, /* class_data */
- sizeof (ESpinner),
- 0, /* n_preallocs */
- (GInstanceInitFunc) e_spinner_init
- };
-
- type = g_type_register_static (GTK_TYPE_WIDGET,
- "ESpinner",
- &our_info, 0);
- }
-
- return type;
-}
-
-static gboolean
-e_spinner_load_images (ESpinner *spinner)
-{
- ESpinnerDetails *details = spinner->details;
-
- if (details->need_load)
- {
- START_PROFILER ("e_spinner_load_images")
-
- details->images =
- e_spinner_cache_get_images
- (details->cache,
- gtk_widget_get_screen (GTK_WIDGET (spinner)),
- details->size);
-
- STOP_PROFILER ("e_spinner_load_images")
-
- details->current_image = 0; /* 'rest' icon */
- details->need_load = FALSE;
- }
-
- return details->images != NULL;
-}
-
-static void
-e_spinner_unload_images (ESpinner *spinner)
-{
- ESpinnerDetails *details = spinner->details;
-
- if (details->images != NULL)
- {
- e_spinner_images_unref (details->images);
- details->images = NULL;
- }
-
- details->current_image = 0;
- details->need_load = TRUE;
-}
-
-static void
-icon_theme_changed_cb (GtkIconTheme *icon_theme,
- ESpinner *spinner)
-{
- e_spinner_unload_images (spinner);
- gtk_widget_queue_resize (GTK_WIDGET (spinner));
-}
-
-static void
-e_spinner_init (ESpinner *spinner)
-{
- ESpinnerDetails *details;
-
- details = spinner->details = E_SPINNER_GET_PRIVATE (spinner);
-
- GTK_WIDGET_SET_FLAGS (GTK_WIDGET (spinner), GTK_NO_WINDOW);
-
- details->cache = e_spinner_cache_ref ();
- details->size = GTK_ICON_SIZE_DIALOG;
- details->spinning = FALSE;
- details->timeout = SPINNER_TIMEOUT;
- details->need_load = TRUE;
-}
-
-static gint
-e_spinner_expose (GtkWidget *widget,
- GdkEventExpose *event)
-{
- ESpinner *spinner = E_SPINNER (widget);
- ESpinnerDetails *details = spinner->details;
- ESpinnerImages *images;
- GtkAllocation allocation;
- GdkPixbuf *pixbuf;
- GdkWindow *window;
- GdkGC *gc;
- gint x_offset, y_offset, width, height;
- GdkRectangle pix_area, dest;
-
-#if GTK_CHECK_VERSION(2,19,7)
- if (!gtk_widget_is_drawable (GTK_WIDGET (spinner)))
-#else
- if (!GTK_WIDGET_DRAWABLE (spinner))
-#endif
- {
- return FALSE;
- }
-
- if (details->need_load &&
- !e_spinner_load_images (spinner))
- {
- return FALSE;
- }
-
- images = details->images;
- if (images == NULL)
- {
- return FALSE;
- }
-
- /* Otherwise |images| will be NULL anyway */
- g_return_val_if_fail (images->n_animation_pixbufs > 0, FALSE);
-
- g_return_val_if_fail (
- details->current_image < images->n_animation_pixbufs, FALSE);
-
- pixbuf = images->animation_pixbufs[details->current_image];
-
- g_return_val_if_fail (pixbuf != NULL, FALSE);
-
- width = gdk_pixbuf_get_width (pixbuf);
- height = gdk_pixbuf_get_height (pixbuf);
-
- gtk_widget_get_allocation (widget, &allocation);
-
- /* Compute the offsets for the image centered on our allocation */
- x_offset = (allocation.width - width) / 2;
- y_offset = (allocation.height - height) / 2;
-
- pix_area.x = x_offset + allocation.x;
- pix_area.y = y_offset + allocation.y;
- pix_area.width = width;
- pix_area.height = height;
-
- if (!gdk_rectangle_intersect (&event->area, &pix_area, &dest))
- {
- return FALSE;
- }
-
- window = gtk_widget_get_window (widget);
-
- gc = gdk_gc_new (window);
- gdk_draw_pixbuf (window, gc, pixbuf,
- dest.x - x_offset - allocation.x,
- dest.y - y_offset - allocation.y,
- dest.x, dest.y,
- dest.width, dest.height,
- GDK_RGB_DITHER_MAX, 0, 0);
- g_object_unref (gc);
-
- return FALSE;
-}
-
-static gboolean
-bump_spinner_frame_cb (ESpinner *spinner)
-{
- ESpinnerDetails *details = spinner->details;
-
- /* This can happen when we've unloaded the images on a theme
- * change, but haven't been in the queued size request yet.
- * Just skip this update.
- */
- if (details->images == NULL) return TRUE;
-
- details->current_image++;
- if (details->current_image >= details->images->n_animation_pixbufs)
- {
- /* the 0th frame is the 'rest' icon */
- details->current_image = MIN (1, details->images->n_animation_pixbufs);
- }
-
- gtk_widget_queue_draw (GTK_WIDGET (spinner));
-
- /* run again */
- return TRUE;
-}
-
-static void
-e_spinner_start (ESpinner *spinner)
-{
- ESpinnerDetails *details = spinner->details;
-
- details->spinning = TRUE;
-
-#if GTK_CHECK_VERSION(2,19,7)
- if (gtk_widget_get_mapped (GTK_WIDGET (spinner)) &&
-#else
- if (GTK_WIDGET_MAPPED (GTK_WIDGET (spinner)) &&
-#endif
- details->timer_task == 0 &&
- e_spinner_load_images (spinner))
- {
- /* the 0th frame is the 'rest' icon */
- details->current_image = MIN (1, details->images->n_animation_pixbufs);
-
- details->timer_task =
- g_timeout_add_full (G_PRIORITY_LOW,
- details->timeout,
- (GSourceFunc) bump_spinner_frame_cb,
- spinner,
- NULL);
- }
-}
-
-static void
-e_spinner_remove_update_callback (ESpinner *spinner)
-{
- ESpinnerDetails *details = spinner->details;
-
- if (details->timer_task != 0)
- {
- g_source_remove (details->timer_task);
- details->timer_task = 0;
- }
-}
-
-static void
-e_spinner_set_size (ESpinner *spinner,
- GtkIconSize size)
-{
- if (size == GTK_ICON_SIZE_INVALID)
- {
- size = GTK_ICON_SIZE_DIALOG;
- }
-
- if (size != spinner->details->size)
- {
- e_spinner_unload_images (spinner);
-
- spinner->details->size = size;
-
- gtk_widget_queue_resize (GTK_WIDGET (spinner));
- }
-}
-
-#if 0
-
-static void
-e_spinner_stop (ESpinner *spinner)
-{
- ESpinnerDetails *details = spinner->details;
-
- details->spinning = FALSE;
- details->current_image = 0;
-
- if (details->timer_task != 0)
- {
- e_spinner_remove_update_callback (spinner);
-
- if (GTK_WIDGET_MAPPED (GTK_WIDGET (spinner)))
- {
- gtk_widget_queue_draw (GTK_WIDGET (spinner));
- }
- }
-}
-
-/*
- * e_spinner_set_timeout:
- * @spinner: a #ESpinner
- * @timeout: time delay between updates to the spinner.
- *
- * Sets the timeout delay for spinner updates.
- **/
-void
-e_spinner_set_timeout (ESpinner *spinner,
- guint timeout)
-{
- ESpinnerDetails *details = spinner->details;
-
- if (timeout != details->timeout)
- {
- e_spinner_stop (spinner);
-
- details->timeout = timeout;
-
- if (details->spinning)
- {
- e_spinner_start (spinner);
- }
- }
-}
-#endif
-
-static void
-e_spinner_size_request (GtkWidget *widget,
- GtkRequisition *requisition)
-{
- ESpinner *spinner = E_SPINNER (widget);
- ESpinnerDetails *details = spinner->details;
-
- if ((details->need_load &&
- !e_spinner_load_images (spinner)) ||
- details->images == NULL)
- {
- requisition->width = requisition->height = 0;
- gtk_icon_size_lookup_for_settings (gtk_widget_get_settings (widget),
- details->size,
- &requisition->width,
- &requisition->height);
- return;
- }
-
- requisition->width = details->images->width;
- requisition->height = details->images->height;
-
- /* FIXME fix this hack */
- /* allocate some extra margin so we don't butt up against toolbar edges */
- if (details->size != GTK_ICON_SIZE_MENU)
- {
- requisition->width += 2;
- requisition->height += 2;
- }
-}
-
-static void
-e_spinner_map (GtkWidget *widget)
-{
- ESpinner *spinner = E_SPINNER (widget);
- ESpinnerDetails *details = spinner->details;
-
- GTK_WIDGET_CLASS (parent_class)->map (widget);
-
- if (details->spinning)
- {
- e_spinner_start (spinner);
- }
-}
-
-static void
-e_spinner_unmap (GtkWidget *widget)
-{
- ESpinner *spinner = E_SPINNER (widget);
-
- e_spinner_remove_update_callback (spinner);
-
- GTK_WIDGET_CLASS (parent_class)->unmap (widget);
-}
-
-static void
-e_spinner_dispose (GObject *object)
-{
- ESpinner *spinner = E_SPINNER (object);
-
- if (spinner->details->icon_theme)
- g_signal_handlers_disconnect_by_func
- (spinner->details->icon_theme,
- G_CALLBACK (icon_theme_changed_cb), spinner);
-
- G_OBJECT_CLASS (parent_class)->dispose (object);
-}
-
-static void
-e_spinner_finalize (GObject *object)
-{
- ESpinner *spinner = E_SPINNER (object);
-
- e_spinner_remove_update_callback (spinner);
- e_spinner_unload_images (spinner);
-
- g_object_unref (spinner->details->cache);
-
- G_OBJECT_CLASS (parent_class)->finalize (object);
-}
-
-static void
-e_spinner_screen_changed (GtkWidget *widget,
- GdkScreen *old_screen)
-{
- ESpinner *spinner = E_SPINNER (widget);
- ESpinnerDetails *details = spinner->details;
- GdkScreen *screen;
-
- if (GTK_WIDGET_CLASS (parent_class)->screen_changed)
- {
- GTK_WIDGET_CLASS (parent_class)->screen_changed (widget, old_screen);
- }
-
- screen = gtk_widget_get_screen (widget);
-
- /* FIXME: this seems to be happening when then spinner is destroyed!? */
- if (old_screen == screen) return;
-
- /* We'll get mapped again on the new screen, but not unmapped from
- * the old screen, so remove timeout here.
- */
- e_spinner_remove_update_callback (spinner);
-
- e_spinner_unload_images (spinner);
-
- if (old_screen != NULL)
- {
- g_signal_handlers_disconnect_by_func
- (gtk_icon_theme_get_for_screen (old_screen),
- G_CALLBACK (icon_theme_changed_cb), spinner);
- }
-
- details->icon_theme = gtk_icon_theme_get_for_screen (screen);
- g_signal_connect (details->icon_theme, "changed",
- G_CALLBACK (icon_theme_changed_cb), spinner);
-}
-
-static void
-e_spinner_class_init (ESpinnerClass *class)
-{
- GObjectClass *object_class = G_OBJECT_CLASS (class);
- GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (class);
-
- parent_class = g_type_class_peek_parent (class);
-
- object_class->dispose = e_spinner_dispose;
- object_class->finalize = e_spinner_finalize;
-
- widget_class->expose_event = e_spinner_expose;
- widget_class->size_request = e_spinner_size_request;
- widget_class->map = e_spinner_map;
- widget_class->unmap = e_spinner_unmap;
- widget_class->screen_changed = e_spinner_screen_changed;
-
- g_type_class_add_private (object_class, sizeof (ESpinnerDetails));
-}
-
-GtkWidget *e_spinner_new_spinning_small_shown (void)
-{
- ESpinner *image;
- image = E_SPINNER (g_object_new (E_TYPE_SPINNER, NULL));
-
- e_spinner_set_size (image, GTK_ICON_SIZE_SMALL_TOOLBAR);
- e_spinner_start (image);
- gtk_widget_show (GTK_WIDGET(image));
-
- return GTK_WIDGET (image);
-}
diff --git a/widgets/misc/e-spinner.h b/widgets/misc/e-spinner.h
deleted file mode 100644
index 0fb97d945e..0000000000
--- a/widgets/misc/e-spinner.h
+++ /dev/null
@@ -1,39 +0,0 @@
-/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */
-/*
- * Copyright © 2000 Eazel, Inc.
- * Copyright © 2004, 2006 Christian Persch
- *
- * Nautilus is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * Nautilus is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
- *
- * Author: Andy Hertzfeld <andy@eazel.com>
- *
- * $Id: ephy-spinner.h 12639 2006-12-12 17:06:55Z chpe $
- */
-
-/*
- * From Nautilus ephy-spinner.h
- */
-#ifndef E_SPINNER_H
-#define E_SPINNER_H
-
-#include <gtk/gtk.h>
-
-G_BEGIN_DECLS
-
-GtkWidget *e_spinner_new_spinning_small_shown (void);
-
-G_END_DECLS
-
-#endif /* E_SPINNER_H */