gimp r26386 - in trunk: . app/gui
- From: neo svn gnome org
- To: svn-commits-list gnome org
- Subject: gimp r26386 - in trunk: . app/gui
- Date: Tue, 5 Aug 2008 16:09:29 +0000 (UTC)
Author: neo
Date: Tue Aug 5 16:09:29 2008
New Revision: 26386
URL: http://svn.gnome.org/viewvc/gimp?rev=26386&view=rev
Log:
2008-08-05 Sven Neumann <sven gimp org>
* app/gui/gimpdbusservice.[ch]: keep a queue of D-Bus requests
and
work on them one after another instead of handling them all in
parallel. Complements the fix for bug #546426.
Modified:
trunk/ChangeLog
trunk/app/gui/gimpdbusservice.c
trunk/app/gui/gimpdbusservice.h
Modified: trunk/app/gui/gimpdbusservice.c
==============================================================================
--- trunk/app/gui/gimpdbusservice.c (original)
+++ trunk/app/gui/gimpdbusservice.c Tue Aug 5 16:09:29 2008
@@ -39,15 +39,42 @@
#include "gimpdbusservice-glue.h"
+typedef struct
+{
+ Gimp *gimp;
+ gchar *uri;
+ gboolean as_new;
+} OpenData;
+
+
static void gimp_dbus_service_class_init (GimpDBusServiceClass *klass);
static void gimp_dbus_service_init (GimpDBusService *service);
+static void gimp_dbus_service_dispose (GObject *object);
+static void gimp_dbus_service_finalize (GObject *object);
+
+static void gimp_dbus_service_queue_open (GimpDBusService *service,
+ const gchar *uri,
+ gboolean as_new);
+
+static OpenData * gimp_dbus_service_open_data_new (GimpDBusService *service,
+ const gchar *uri,
+ gboolean as_new);
+static void gimp_dbus_service_open_data_free (OpenData *data);
+
G_DEFINE_TYPE (GimpDBusService, gimp_dbus_service, G_TYPE_OBJECT)
+#define parent_class gimp_dbus_service_parent_class
+
static void
gimp_dbus_service_class_init (GimpDBusServiceClass *klass)
{
+ GObjectClass *object_class = G_OBJECT_CLASS (klass);
+
+ object_class->dispose = gimp_dbus_service_dispose;
+ object_class->finalize = gimp_dbus_service_finalize;
+
dbus_g_object_type_install_info (G_TYPE_FROM_CLASS (klass),
&dbus_glib_gimp_object_info);
}
@@ -55,6 +82,7 @@
static void
gimp_dbus_service_init (GimpDBusService *service)
{
+ service->queue = g_queue_new ();
}
GObject *
@@ -71,42 +99,37 @@
return G_OBJECT (service);
}
-typedef struct
-{
- Gimp *gimp;
- gchar *uri;
- gboolean as_new;
-} IdleData;
-
-static IdleData *
-gimp_dbus_service_open_idle_new (GimpDBusService *service,
- const gchar *uri,
- gboolean as_new)
+static void
+gimp_dbus_service_dispose (GObject *object)
{
- IdleData *data = g_slice_new (IdleData);
+ GimpDBusService *service = GIMP_DBUS_SERVICE (object);
- data->gimp = g_object_ref (service->gimp);
- data->uri = g_strdup (uri);
- data->as_new = as_new;
+ if (service->source)
+ {
+ g_source_remove (g_source_get_id (service->source));
+ service->source = NULL;
+ }
+
+ while (! g_queue_is_empty (service->queue))
+ {
+ gimp_dbus_service_open_data_free (g_queue_pop_head (service->queue));
+ }
- return data;
+ G_OBJECT_CLASS (parent_class)->dispose (object);
}
static void
-gimp_dbus_service_open_idle_free (IdleData *data)
+gimp_dbus_service_finalize (GObject *object)
{
- g_object_unref (data->gimp);
- g_free (data->uri);
+ GimpDBusService *service = GIMP_DBUS_SERVICE (object);
- g_slice_free (IdleData, data);
-}
-
-static gboolean
-gimp_dbus_service_open_idle (IdleData *data)
-{
- file_open_from_command_line (data->gimp, data->uri, data->as_new);
+ if (service->queue)
+ {
+ g_queue_free (service->queue);
+ service->queue = NULL;
+ }
- return FALSE;
+ G_OBJECT_CLASS (parent_class)->finalize (object);
}
gboolean
@@ -119,10 +142,7 @@
g_return_val_if_fail (uri != NULL, FALSE);
g_return_val_if_fail (success != NULL, FALSE);
- g_idle_add_full (G_PRIORITY_DEFAULT_IDLE,
- (GSourceFunc) gimp_dbus_service_open_idle,
- gimp_dbus_service_open_idle_new (service, uri, FALSE),
- (GDestroyNotify) gimp_dbus_service_open_idle_free);
+ gimp_dbus_service_queue_open (service, uri, FALSE);
/* The call always succeeds as it is handled in one way or another.
* Even presenting an error message is considered success ;-)
@@ -142,10 +162,7 @@
g_return_val_if_fail (uri != NULL, FALSE);
g_return_val_if_fail (success != NULL, FALSE);
- g_idle_add_full (G_PRIORITY_DEFAULT_IDLE,
- (GSourceFunc) gimp_dbus_service_open_idle,
- gimp_dbus_service_open_idle_new (service, uri, TRUE),
- (GDestroyNotify) gimp_dbus_service_open_idle_free);
+ gimp_dbus_service_queue_open (service, uri, TRUE);
/* The call always succeeds as it is handled in one way or another.
* Even presenting an error message is considered success ;-)
@@ -170,5 +187,63 @@
return TRUE;
}
+static OpenData *
+gimp_dbus_service_open_data_new (GimpDBusService *service,
+ const gchar *uri,
+ gboolean as_new)
+{
+ OpenData *data = g_slice_new (OpenData);
+
+ data->gimp = g_object_ref (service->gimp);
+ data->uri = g_strdup (uri);
+ data->as_new = as_new;
+
+ return data;
+}
+
+static void
+gimp_dbus_service_open_data_free (OpenData *data)
+{
+ g_object_unref (data->gimp);
+ g_free (data->uri);
+
+ g_slice_free (OpenData, data);
+}
+
+static gboolean
+gimp_dbus_service_open_idle (GQueue *queue)
+{
+ OpenData *data = g_queue_pop_tail (queue);
+
+ if (data)
+ {
+ file_open_from_command_line (data->gimp, data->uri, data->as_new);
+ gimp_dbus_service_open_data_free (data);
+
+ return TRUE;
+ }
+
+ return FALSE;
+}
+
+static void
+gimp_dbus_service_queue_open (GimpDBusService *service,
+ const gchar *uri,
+ gboolean as_new)
+{
+ g_queue_push_tail (service->queue,
+ gimp_dbus_service_open_data_new (service, uri, as_new));
+
+ if (! service->source)
+ {
+ service->source = g_idle_source_new ();
+
+ g_source_set_callback (service->source,
+ (GSourceFunc) gimp_dbus_service_open_idle,
+ service->queue, NULL);
+ g_source_attach (service->source, NULL);
+ g_source_unref (service->source);
+ }
+}
#endif /* HAVE_DBUS_GLIB */
Modified: trunk/app/gui/gimpdbusservice.h
==============================================================================
--- trunk/app/gui/gimpdbusservice.h (original)
+++ trunk/app/gui/gimpdbusservice.h Tue Aug 5 16:09:29 2008
@@ -46,6 +46,8 @@
GObject parent_instance;
Gimp *gimp;
+ GQueue *queue;
+ GSource *source;
};
struct _GimpDBusServiceClass
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]