[tracker/clientapi-2: 12/20] libtracker-client: Don't try to start the D-Bus service at all
- From: Philip Van Hoof <pvanhoof src gnome org>
- To: svn-commits-list gnome org
- Cc:
- Subject: [tracker/clientapi-2: 12/20] libtracker-client: Don't try to start the D-Bus service at all
- Date: Thu, 14 Jan 2010 12:33:03 +0000 (UTC)
commit 123f8f479df2d1f98c8312c00e386aaf6e82b019
Author: Martyn Russell <martyn lanedo com>
Date: Wed Jan 13 12:55:48 2010 +0000
libtracker-client: Don't try to start the D-Bus service at all
This is done automatically with D-Bus calls anyway.
src/libtracker-client/tracker.c | 116 ++++++++-------------
src/libtracker-client/tracker.h | 6 +-
src/plugins/evolution/tracker-evolution-plugin.c | 8 +-
3 files changed, 48 insertions(+), 82 deletions(-)
---
diff --git a/src/libtracker-client/tracker.c b/src/libtracker-client/tracker.c
index 9fd2e01..2ff5ae9 100644
--- a/src/libtracker-client/tracker.c
+++ b/src/libtracker-client/tracker.c
@@ -97,7 +97,8 @@ typedef struct {
gint timeout;
gboolean enable_warnings;
- gboolean force_service;
+
+ gboolean is_constructed;
} TrackerClientPrivate;
typedef struct {
@@ -145,7 +146,6 @@ static void client_constructed (GObject *object);
enum {
PROP_0,
PROP_ENABLE_WARNINGS,
- PROP_FORCE_SERVICE,
PROP_TIMEOUT,
};
@@ -187,39 +187,6 @@ pending_call_new (TrackerClient *client,
return id;
}
-static gboolean
-start_service (DBusConnection *connection,
- const char *name)
-{
- DBusError error;
- DBusMessage *request, *reply;
- guint32 flags;
-
- dbus_error_init (&error);
-
- flags = 0;
-
- request = dbus_message_new_method_call (DBUS_SERVICE_DBUS, DBUS_PATH_DBUS, DBUS_INTERFACE_DBUS, "StartServiceByName");
- dbus_message_append_args (request, DBUS_TYPE_STRING, &name, DBUS_TYPE_UINT32, &flags, DBUS_TYPE_INVALID);
-
- reply = dbus_connection_send_with_reply_and_block (connection, request, -1, &error);
- dbus_message_unref (request);
-
- if (reply == NULL) {
- dbus_error_free (&error);
- return FALSE;
- }
-
- if (dbus_set_error_from_message (&error, reply)) {
- dbus_message_unref (reply);
- dbus_error_free (&error);
- return FALSE;
- }
-
- dbus_message_unref (reply);
- return TRUE;
-}
-
static void
tracker_client_class_init (TrackerClientClass *klass)
{
@@ -240,20 +207,13 @@ tracker_client_class_init (TrackerClientClass *klass)
TRUE,
G_PARAM_READWRITE | G_PARAM_CONSTRUCT));
g_object_class_install_property (object_class,
- PROP_FORCE_SERVICE,
- g_param_spec_boolean ("force-service",
- "Force service startup",
- "Force service startup",
- TRUE,
- G_PARAM_READWRITE | G_PARAM_CONSTRUCT));
- g_object_class_install_property (object_class,
PROP_TIMEOUT,
g_param_spec_int ("timeout",
"Timeout",
"Timeout",
- 0,
+ G_MININT,
G_MAXINT,
- 0,
+ -1,
G_PARAM_READWRITE | G_PARAM_CONSTRUCT));
g_type_class_add_private (object_class, sizeof (TrackerClientPrivate));
@@ -262,6 +222,11 @@ tracker_client_class_init (TrackerClientClass *klass)
static void
tracker_client_init (TrackerClient *client)
{
+ TrackerClientPrivate *private = TRACKER_CLIENT_GET_PRIVATE (client);
+
+ private->timeout = -1;
+ private->pending_calls = g_hash_table_new_full (NULL, NULL, NULL,
+ (GDestroyNotify) pending_call_free);
}
static void
@@ -289,23 +254,21 @@ client_set_property (GObject *object,
GParamSpec *pspec)
{
TrackerClientPrivate *private = TRACKER_CLIENT_GET_PRIVATE (object);
- gint val;
switch (prop_id) {
case PROP_ENABLE_WARNINGS:
private->enable_warnings = g_value_get_boolean (value);
break;
- case PROP_FORCE_SERVICE:
- private->force_service = g_value_get_boolean (value);
- break;
case PROP_TIMEOUT:
- val = g_value_get_int (value);
- if (val > 0) {
- private->timeout = val;
- dbus_g_proxy_set_default_timeout (private->proxy_resources, val);
+ private->timeout = g_value_get_int (value);
+
+ if (private->is_constructed) {
+ dbus_g_proxy_set_default_timeout (private->proxy_resources,
+ private->timeout);
}
break;
default:
+
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
}
}
@@ -316,17 +279,14 @@ client_get_property (GObject *object,
GValue *value,
GParamSpec *pspec)
{
- TrackerClientPrivate *priv = TRACKER_CLIENT_GET_PRIVATE (object);
+ TrackerClientPrivate *private = TRACKER_CLIENT_GET_PRIVATE (object);
switch (prop_id) {
case PROP_ENABLE_WARNINGS:
- g_value_set_boolean (value, priv->enable_warnings);
- break;
- case PROP_FORCE_SERVICE:
- g_value_set_boolean (value, priv->force_service);
+ g_value_set_boolean (value, private->enable_warnings);
break;
case PROP_TIMEOUT:
- g_value_set_int (value, priv->timeout);
+ g_value_set_int (value, private->timeout);
break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
@@ -353,17 +313,7 @@ client_constructed (GObject *object)
return;
}
- if (private->force_service) {
- if (!start_service (dbus_g_connection_get_connection (connection),
- TRACKER_DBUS_SERVICE)) {
- /* unable to start tracker-store */
- dbus_g_connection_unref (connection);
- return;
- }
- }
-
- private->pending_calls = g_hash_table_new_full (NULL, NULL, NULL,
- (GDestroyNotify) pending_call_free);
+ g_debug ("Got connection to service %p", connection);
private->proxy_statistics =
dbus_g_proxy_new_for_name (connection,
@@ -371,11 +321,24 @@ client_constructed (GObject *object)
TRACKER_DBUS_OBJECT "/Statistics",
TRACKER_DBUS_INTERFACE_STATISTICS);
+ g_debug ("Got proxy for stats %p", private->proxy_statistics);
+
private->proxy_resources =
dbus_g_proxy_new_for_name (connection,
TRACKER_DBUS_SERVICE,
TRACKER_DBUS_OBJECT "/Resources",
TRACKER_DBUS_INTERFACE_RESOURCES);
+
+ g_debug ("Got proxy for resources %p", private->proxy_resources);
+
+ /* NOTE: We don't need to set this for the stats proxy, the
+ * query takes no arguments and is generally really fast.
+ */
+ dbus_g_proxy_set_default_timeout (private->proxy_resources,
+ private->timeout);
+ g_debug ("Set timeout to %d", private->timeout);
+
+ private->is_constructed = TRUE;
}
static void
@@ -528,11 +491,14 @@ TrackerClient *
tracker_client_new (TrackerClientFlags flags,
gint timeout)
{
+ gboolean enable_warnings;
+
g_type_init ();
+ enable_warnings = (flags & TRACKER_CLIENT_ENABLE_WARNINGS);
+
return g_object_new (TRACKER_TYPE_CLIENT,
- "enable-warnings", (flags & TRACKER_CLIENT_ENABLE_WARNINGS),
- "force-service", !(flags & TRACKER_CLIENT_DO_NOT_START_SERVICE),
+ "enable-warnings", enable_warnings,
"timeout", timeout,
NULL);
}
@@ -1133,7 +1099,13 @@ TrackerClient *
tracker_connect (gboolean enable_warnings,
gint timeout)
{
- return tracker_client_new (TRACKER_CLIENT_ENABLE_WARNINGS, timeout);
+ TrackerClientFlags flags = 0;
+
+ if (enable_warnings) {
+ flags |= TRACKER_CLIENT_ENABLE_WARNINGS;
+ }
+
+ return tracker_client_new (flags, timeout);
}
/**
diff --git a/src/libtracker-client/tracker.h b/src/libtracker-client/tracker.h
index cf54cf0..11766a0 100644
--- a/src/libtracker-client/tracker.h
+++ b/src/libtracker-client/tracker.h
@@ -50,13 +50,9 @@ typedef struct {
* @TRACKER_CLIENT_ENABLE_WARNINGS: If supplied warnings will be
* produced upon erronous situations. This is usually turned off for
* applications that want to provide their own error reporting.
- * @TRACKER_CLIENT_DO_NOT_START_SERVICE: If supplied then creating a
- * new #TrackerClient #GObject will not attempt start the D-Bus
- * service for tracker-store pre-emptively.
*/
typedef enum {
- TRACKER_CLIENT_ENABLE_WARNINGS = 1 << 1,
- TRACKER_CLIENT_DO_NOT_START_SERVICE = 1 << 2,
+ TRACKER_CLIENT_ENABLE_WARNINGS = 1 << 0,
} TrackerClientFlags;
/**
diff --git a/src/plugins/evolution/tracker-evolution-plugin.c b/src/plugins/evolution/tracker-evolution-plugin.c
index 7587215..592c95e 100644
--- a/src/plugins/evolution/tracker-evolution-plugin.c
+++ b/src/plugins/evolution/tracker-evolution-plugin.c
@@ -2148,8 +2148,7 @@ name_owner_changed_cb (DBusGProxy *proxy,
if (tracker_is_empty_string (old_owner) && !tracker_is_empty_string (new_owner)) {
if (!priv->client) {
- priv->client = tracker_client_new (TRACKER_CLIENT_DO_NOT_START_SERVICE,
- G_MAXINT);
+ priv->client = tracker_client_new (0, G_MAXINT);
}
register_client (user_data);
}
@@ -2342,8 +2341,7 @@ miner_started (TrackerMiner *miner)
g_static_rec_mutex_lock (priv->mutex);
if (!priv->client) {
- priv->client = tracker_client_new (TRACKER_CLIENT_DO_NOT_START_SERVICE,
- G_MAXINT);
+ priv->client = tracker_client_new (0, G_MAXINT);
}
g_static_rec_mutex_unlock (priv->mutex);
@@ -2446,7 +2444,7 @@ miner_resumed (TrackerMiner *miner)
priv->of_total = 0;
if (!priv->client) {
- priv->client = tracker_client_new (TRACKER_CLIENT_DO_NOT_START_SERVICE, G_MAXINT);
+ priv->client = tracker_client_new (0, G_MAXINT);
}
g_static_rec_mutex_unlock (priv->mutex);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]