[tracker/tracker-0.12] tracker-extract: Use g_(mutex|cond)_(init|clear) if GLib >= 2.31
- From: Martyn James Russell <mr src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/tracker-0.12] tracker-extract: Use g_(mutex|cond)_(init|clear) if GLib >= 2.31
- Date: Fri, 16 Dec 2011 16:49:26 +0000 (UTC)
commit a97d05b8f39d32cb9f6e1be4ad3e3455d420e3bd
Author: Aleksander Morgado <aleksander lanedo com>
Date: Fri Dec 16 11:16:21 2011 +0100
tracker-extract: Use g_(mutex|cond)_(init|clear) if GLib >= 2.31
Since 2.31, g_mutex_new(), g_mutex_free(), g_cond_new(), g_cond_free() are
deprecated.
src/tracker-extract/tracker-controller.c | 37 +++++++++++++++++++++--
src/tracker-extract/tracker-extract.c | 46 ++++++++++++++++++++++++++++--
2 files changed, 76 insertions(+), 7 deletions(-)
---
diff --git a/src/tracker-extract/tracker-controller.c b/src/tracker-extract/tracker-controller.c
index a52ecbe..6c059fc 100644
--- a/src/tracker-extract/tracker-controller.c
+++ b/src/tracker-extract/tracker-controller.c
@@ -59,9 +59,15 @@ struct TrackerControllerPrivate {
guint shutdown_timeout;
GSource *shutdown_source;
+
+ GError *initialization_error;
+#if GLIB_CHECK_VERSION (2,31,0)
+ GCond initialization_cond;
+ GMutex initialization_mutex;
+#else
GCond *initialization_cond;
GMutex *initialization_mutex;
- GError *initialization_error;
+#endif
guint initialized : 1;
};
@@ -166,8 +172,13 @@ tracker_controller_finalize (GObject *object)
g_main_loop_unref (priv->main_loop);
g_main_context_unref (priv->context);
+#if GLIB_CHECK_VERSION (2,31,0)
+ g_cond_clear (&priv->initialization_cond);
+ g_mutex_clear (&priv->initialization_mutex);
+#else
g_cond_free (priv->initialization_cond);
g_mutex_free (priv->initialization_mutex);
+#endif
G_OBJECT_CLASS (tracker_controller_parent_class)->finalize (object);
}
@@ -400,8 +411,13 @@ tracker_controller_init (TrackerController *controller)
g_signal_connect (priv->storage, "mount-point-removed",
G_CALLBACK (mount_point_removed_cb), controller);
+#if GLIB_CHECK_VERSION (2,31,0)
+ g_cond_init (&priv->initialization_cond);
+ g_mutex_init (&priv->initialization_mutex);
+#else
priv->initialization_cond = g_cond_new ();
priv->initialization_mutex = g_mutex_new ();
+#endif
}
static void
@@ -775,15 +791,23 @@ controller_notify_main_thread (TrackerController *controller,
priv = controller->priv;
+#if GLIB_CHECK_VERSION (2,31,0)
+ g_mutex_lock (&priv->initialization_mutex);
+#else
g_mutex_lock (priv->initialization_mutex);
+#endif
priv->initialized = TRUE;
priv->initialization_error = error;
/* Notify about the initialization */
+#if GLIB_CHECK_VERSION (2,31,0)
+ g_cond_signal (&priv->initialization_cond);
+ g_mutex_unlock (&priv->initialization_mutex);
+#else
g_cond_signal (priv->initialization_cond);
-
g_mutex_unlock (priv->initialization_mutex);
+#endif
}
static void
@@ -980,13 +1004,18 @@ tracker_controller_start (TrackerController *controller,
#endif /* THREAD_ENABLE_TRACE */
/* Wait for the controller thread to notify initialization */
+#if GLIB_CHECK_VERSION (2,31,0)
+ g_mutex_lock (&priv->initialization_mutex);
+ while (!priv->initialized)
+ g_cond_wait (&priv->initialization_cond, &priv->initialization_mutex);
+ g_mutex_unlock (&priv->initialization_mutex);
+#else
g_mutex_lock (priv->initialization_mutex);
-
while (!priv->initialized) {
g_cond_wait (priv->initialization_cond, priv->initialization_mutex);
}
-
g_mutex_unlock (priv->initialization_mutex);
+#endif
/* If there was any error resulting from initialization, propagate it */
if (priv->initialization_error != NULL) {
diff --git a/src/tracker-extract/tracker-extract.c b/src/tracker-extract/tracker-extract.c
index 71b6e22..ce78e1b 100644
--- a/src/tracker-extract/tracker-extract.c
+++ b/src/tracker-extract/tracker-extract.c
@@ -61,7 +61,11 @@ typedef struct {
/* used to maintain the running tasks
* and stats from different threads
*/
+#if GLIB_CHECK_VERSION (2,31,0)
+ GMutex task_mutex;
+#else
GMutex *task_mutex;
+#endif
/* Thread pool for multi-threaded extractors */
GThreadPool *thread_pool;
@@ -140,7 +144,11 @@ tracker_extract_init (TrackerExtract *object)
priv->thread_pool = g_thread_pool_new ((GFunc) get_metadata,
NULL, 10, TRUE, NULL);
+#if GLIB_CHECK_VERSION (2,31,0)
+ g_mutex_init (&priv->task_mutex);
+#else
priv->task_mutex = g_mutex_new ();
+#endif
}
static void
@@ -165,9 +173,11 @@ tracker_extract_finalize (GObject *object)
g_hash_table_destroy (priv->statistics_data);
- if (priv->task_mutex) {
- g_mutex_free (priv->task_mutex);
- }
+#if GLIB_CHECK_VERSION (2,31,0)
+ g_mutex_clear (&priv->task_mutex);
+#else
+ g_mutex_free (priv->task_mutex);
+#endif
G_OBJECT_CLASS (tracker_extract_parent_class)->finalize (object);
}
@@ -181,7 +191,11 @@ report_statistics (GObject *object)
priv = TRACKER_EXTRACT_GET_PRIVATE (object);
+#if GLIB_CHECK_VERSION (2,31,0)
+ g_mutex_lock (&priv->task_mutex);
+#else
g_mutex_lock (priv->task_mutex);
+#endif
g_message ("--------------------------------------------------");
g_message ("Statistics:");
@@ -214,7 +228,11 @@ report_statistics (GObject *object)
g_message ("--------------------------------------------------");
+#if GLIB_CHECK_VERSION (2,31,0)
+ g_mutex_unlock (&priv->task_mutex);
+#else
g_mutex_unlock (priv->task_mutex);
+#endif
}
TrackerExtract *
@@ -255,7 +273,11 @@ notify_task_finish (TrackerExtractTask *task,
/* Reports and ongoing tasks may be
* accessed from other threads.
*/
+#if GLIB_CHECK_VERSION (2,31,0)
+ g_mutex_lock (&priv->task_mutex);
+#else
g_mutex_lock (priv->task_mutex);
+#endif
stats_data = g_hash_table_lookup (priv->statistics_data,
task->cur_module);
@@ -275,7 +297,11 @@ notify_task_finish (TrackerExtractTask *task,
priv->running_tasks = g_list_remove (priv->running_tasks, task);
+#if GLIB_CHECK_VERSION (2,31,0)
+ g_mutex_unlock (&priv->task_mutex);
+#else
g_mutex_unlock (priv->task_mutex);
+#endif
}
static gboolean
@@ -385,7 +411,11 @@ task_cancellable_cancelled_cb (GCancellable *cancellable,
extract = task->extract;
priv = TRACKER_EXTRACT_GET_PRIVATE (extract);
+#if GLIB_CHECK_VERSION (2,31,0)
+ g_mutex_lock (&priv->task_mutex);
+#else
g_mutex_lock (priv->task_mutex);
+#endif
if (g_list_find (priv->running_tasks, task)) {
g_message ("Cancelled task for '%s' was currently being "
@@ -394,7 +424,11 @@ task_cancellable_cancelled_cb (GCancellable *cancellable,
_exit (0);
}
+#if GLIB_CHECK_VERSION (2,31,0)
+ g_mutex_unlock (&priv->task_mutex);
+#else
g_mutex_unlock (priv->task_mutex);
+#endif
}
static TrackerExtractTask *
@@ -661,9 +695,15 @@ dispatch_task_cb (TrackerExtractTask *task)
return FALSE;
}
+#if GLIB_CHECK_VERSION (2,31,0)
+ g_mutex_lock (&priv->task_mutex);
+ priv->running_tasks = g_list_prepend (priv->running_tasks, task);
+ g_mutex_unlock (&priv->task_mutex);
+#else
g_mutex_lock (priv->task_mutex);
priv->running_tasks = g_list_prepend (priv->running_tasks, task);
g_mutex_unlock (priv->task_mutex);
+#endif
switch (thread_awareness) {
case TRACKER_MODULE_NONE:
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]