[nautilus/previewer: 5/6] previewer: lazily create the DBus proxy
- From: Cosimo Cecchi <cosimoc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [nautilus/previewer: 5/6] previewer: lazily create the DBus proxy
- Date: Wed, 27 Apr 2011 21:19:52 +0000 (UTC)
commit 0cfb82d70446d9599149f3dbeee34789e21d9d5d
Author: Cosimo Cecchi <cosimoc gnome org>
Date: Mon Apr 25 17:54:54 2011 -0400
previewer: lazily create the DBus proxy
src/nautilus-previewer.c | 164 +++++++++++++++++++++++++--------------------
src/nautilus-view.c | 2 +
2 files changed, 93 insertions(+), 73 deletions(-)
---
diff --git a/src/nautilus-previewer.c b/src/nautilus-previewer.c
index c41b823..9c04254 100644
--- a/src/nautilus-previewer.c
+++ b/src/nautilus-previewer.c
@@ -23,6 +23,9 @@
#include "nautilus-previewer.h"
+#define DEBUG_FLAG NAUTILUS_DEBUG_PREVIEWER
+#include <libnautilus-private/nautilus-debug.h>
+
#include <gio/gio.h>
G_DEFINE_TYPE (NautilusPreviewer, nautilus_previewer, G_TYPE_OBJECT);
@@ -34,74 +37,21 @@ G_DEFINE_TYPE (NautilusPreviewer, nautilus_previewer, G_TYPE_OBJECT);
static NautilusPreviewer *singleton = NULL;
struct _NautilusPreviewerPriv {
- guint watch_id;
GDBusProxy *proxy;
-};
-
-static void
-previewer_proxy_async_ready_cb (GObject *source,
- GAsyncResult *res,
- gpointer user_data)
-{
- GDBusProxy *proxy;
- NautilusPreviewer *self = user_data;
- GError *error = NULL;
-
- proxy = g_dbus_proxy_new_finish (res, &error);
-
- if (error != NULL) {
- g_warning ("Unable to create a dbus proxy for NautilusPreviewer: %s",
- error->message);
- g_error_free (error);
-
- return;
- }
-
- self->priv->proxy = proxy;
-}
-
-static void
-previewer_name_appeared_cb (GDBusConnection *conn,
- const gchar *name,
- const gchar *name_owner,
- gpointer user_data)
-{
- NautilusPreviewer *self = user_data;
- g_dbus_proxy_new (conn,
- G_DBUS_PROXY_FLAGS_NONE,
- NULL,
- name,
- PREVIEWER_DBUS_PATH,
- PREVIEWER_DBUS_IFACE,
- NULL,
- previewer_proxy_async_ready_cb,
- self);
-}
+ GVariant *pending_variant;
+};
static void
-previewer_name_vanished_cb (GDBusConnection *conn,
- const gchar *name,
- gpointer user_data)
+nautilus_previewer_dispose (GObject *object)
{
- NautilusPreviewer *self = user_data;
+ NautilusPreviewer *self = NAUTILUS_PREVIEWER (object);
- g_print ("vanished %p %s\n", self, name);
-}
+ DEBUG ("%p", self);
-static void
-nautilus_previewer_constructed (GObject *object)
-{
- NautilusPreviewer *self = NAUTILUS_PREVIEWER (object);
+ g_clear_object (&self->priv->proxy);
- self->priv->watch_id =
- g_bus_watch_name (G_BUS_TYPE_SESSION,
- PREVIEWER_DBUS_NAME,
- G_BUS_NAME_WATCHER_FLAGS_AUTO_START,
- previewer_name_appeared_cb,
- previewer_name_vanished_cb,
- self,
- NULL);
+ G_OBJECT_CLASS (nautilus_previewer_parent_class)->dispose (object);
}
static GObject *
@@ -137,7 +87,7 @@ nautilus_previewer_class_init (NautilusPreviewerClass *klass)
oclass = G_OBJECT_CLASS (klass);
oclass->constructor = nautilus_previewer_constructor;
- oclass->constructed = nautilus_previewer_constructed;
+ oclass->dispose = nautilus_previewer_dispose;
g_type_class_add_private (klass, sizeof (NautilusPreviewerPriv));
}
@@ -158,6 +108,63 @@ previewer_show_file_ready_cb (GObject *source,
error->message);
g_error_free (error);
}
+
+ g_object_unref (self);
+}
+
+static void
+real_call_show_file (NautilusPreviewer *self,
+ GVariant *args)
+{
+ gchar *variant_str;
+
+ variant_str = g_variant_print (args, TRUE);
+ DEBUG ("Calling ShowFile with params %s", variant_str);
+
+ g_dbus_proxy_call (self->priv->proxy,
+ "ShowFile",
+ args,
+ G_DBUS_CALL_FLAGS_NONE,
+ -1,
+ NULL,
+ previewer_show_file_ready_cb,
+ self);
+
+ g_free (variant_str);
+}
+
+static void
+previewer_proxy_async_ready_cb (GObject *source,
+ GAsyncResult *res,
+ gpointer user_data)
+{
+ GDBusProxy *proxy;
+ NautilusPreviewer *self = user_data;
+ GError *error = NULL;
+
+ proxy = g_dbus_proxy_new_finish (res, &error);
+
+ if (error != NULL) {
+ g_warning ("Unable to create a dbus proxy for NautilusPreviewer: %s",
+ error->message);
+ g_error_free (error);
+ g_object_unref (self);
+
+ return;
+ }
+
+ DEBUG ("Got previewer DBus proxy");
+
+ self->priv->proxy = proxy;
+
+ if (self->priv->pending_variant != NULL) {
+ real_call_show_file (self, self->priv->pending_variant);
+
+ g_variant_unref (self->priv->pending_variant);
+ self->priv->pending_variant = NULL;
+ } else {
+ g_object_unref (self);
+ }
}
NautilusPreviewer *
@@ -173,16 +180,27 @@ nautilus_previewer_call_show_file (NautilusPreviewer *self,
guint x,
guint y)
{
- if (!self->priv->proxy)
- return;
-
- g_dbus_proxy_call (self->priv->proxy,
- "ShowFile",
- g_variant_new ("(siii)",
- uri, xid, x, y),
- G_DBUS_CALL_FLAGS_NONE,
- -1,
- NULL,
- previewer_show_file_ready_cb,
- self);
+ GVariant *variant;
+
+ variant = g_variant_new ("(siii)",
+ uri, xid, x, y);
+ g_object_ref (self);
+
+ if (self->priv->proxy == NULL) {
+ if (self->priv->pending_variant != NULL)
+ g_variant_unref (self->priv->pending_variant);
+
+ self->priv->pending_variant = g_variant_ref_sink (variant);
+ g_dbus_proxy_new_for_bus (G_BUS_TYPE_SESSION,
+ G_DBUS_PROXY_FLAGS_NONE,
+ NULL,
+ PREVIEWER_DBUS_NAME,
+ PREVIEWER_DBUS_PATH,
+ PREVIEWER_DBUS_IFACE,
+ NULL,
+ previewer_proxy_async_ready_cb,
+ self);
+ } else {
+ real_call_show_file (self, variant);
+ }
}
diff --git a/src/nautilus-view.c b/src/nautilus-view.c
index 1ddc6e2..9293b6f 100644
--- a/src/nautilus-view.c
+++ b/src/nautilus-view.c
@@ -1137,6 +1137,8 @@ nautilus_view_preview_files (NautilusView *view,
xid = gdk_x11_window_get_xid (gtk_widget_get_window (toplevel));
nautilus_previewer_call_show_file (previewer, uri, xid, x, y);
+
+ g_object_unref (previewer);
}
void
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]