aboutsummaryrefslogtreecommitdiffstats
path: root/calendar/gui/e-meeting-store.c
diff options
context:
space:
mode:
authorChenthill Palanisamy <pchen@src.gnome.org>2006-03-29 17:10:27 +0800
committerChenthill Palanisamy <pchen@src.gnome.org>2006-03-29 17:10:27 +0800
commitd30e7f782ee451e13beac4858ba44b3bd390a768 (patch)
tree969bcfbc3ba6bf7093772e0c2040350399962923 /calendar/gui/e-meeting-store.c
parent675d1e50a6ffa9442de7ecc6257315a4465dff41 (diff)
downloadgsoc2013-evolution-d30e7f782ee451e13beac4858ba44b3bd390a768.tar.gz
gsoc2013-evolution-d30e7f782ee451e13beac4858ba44b3bd390a768.tar.zst
gsoc2013-evolution-d30e7f782ee451e13beac4858ba44b3bd390a768.zip
Fixes #160357
svn path=/trunk/; revision=31755
Diffstat (limited to 'calendar/gui/e-meeting-store.c')
-rw-r--r--calendar/gui/e-meeting-store.c18
1 files changed, 18 insertions, 0 deletions
diff --git a/calendar/gui/e-meeting-store.c b/calendar/gui/e-meeting-store.c
index a942d83779..8a185add17 100644
--- a/calendar/gui/e-meeting-store.c
+++ b/calendar/gui/e-meeting-store.c
@@ -60,6 +60,7 @@ struct _EMeetingStorePrivate {
guint callback_idle_id;
guint num_threads;
+ guint num_queries;
GAsyncQueue *async_queue;
};
@@ -611,6 +612,8 @@ ems_init (EMeetingStore *store)
priv->async_queue = g_async_queue_new ();
+ priv->num_queries = 0;
+
start_addressbook_server (store);
}
@@ -1177,6 +1180,7 @@ typedef struct {
char *email;
EMeetingAttendee *attendee;
EMeetingStoreQueueData *qdata;
+ EMeetingStore *store;
} FreeBusyAsyncData;
#define USER_SUB "%u"
@@ -1189,12 +1193,15 @@ freebusy_async (gpointer data)
EMeetingAttendee *attendee = fbd->attendee;
gchar *default_fb_uri;
static GStaticMutex mutex = G_STATIC_MUTEX_INIT;
+ EMeetingStorePrivate *priv = fbd->store->priv;
if (fbd->client) {
/* FIXME this a work around for getting all th free busy information for the users
we should be able to get free busy asynchronously */
g_static_mutex_lock (&mutex);
+ priv->num_queries++;
e_cal_get_free_busy (fbd->client, fbd->users, fbd->startt, fbd->endt, &(fbd->fb_data), NULL);
+ priv->num_queries--;
g_static_mutex_unlock (&mutex);
g_list_foreach (fbd->users, (GFunc)g_free, NULL);
@@ -1234,9 +1241,11 @@ freebusy_async (gpointer data)
g_free (default_fb_uri);
default_fb_uri = replace_string (tmp_fb_uri, DOMAIN_SUB, split_email[1]);
+ priv->num_queries++;
gnome_vfs_async_open (&handle, default_fb_uri, GNOME_VFS_OPEN_READ,
GNOME_VFS_PRIORITY_DEFAULT, start_async_read,
fbd->qdata);
+ priv->num_queries--;
g_free (tmp_fb_uri);
g_strfreev (split_email);
@@ -1300,6 +1309,7 @@ refresh_busy_periods (gpointer data)
fbd->fb_data = NULL;
fbd->qdata = qdata;
fbd->fb_uri = priv->fb_uri;
+ fbd->store = store;
fbd->email = g_strdup (itip_strip_mailto (e_meeting_attendee_get_address (attendee)));
/* Check the server for free busy data */
@@ -1503,3 +1513,11 @@ e_meeting_store_refresh_busy_periods (EMeetingStore *store,
refresh_queue_add (store, row, start, end, call_back, data);
}
+
+guint
+e_meeting_store_get_num_queries (EMeetingStore *store)
+{
+ g_return_if_fail (E_IS_MEETING_STORE (store));
+
+ return store->priv->num_queries;
+}