[tracker/tracker-0.12] tracker-extract: use g_thread_try_new() 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_thread_try_new() if GLib >= 2.31
- Date: Fri, 16 Dec 2011 16:49:31 +0000 (UTC)
commit e2c9d614bde11e7e58c93d1d3f03d0011f6011ae
Author: Aleksander Morgado <aleksander lanedo com>
Date: Fri Dec 16 11:26:34 2011 +0100
tracker-extract: use g_thread_try_new() if GLib >= 2.31
Since 2.31, g_thread_create() is deprecated.
src/tracker-extract/tracker-controller.c | 14 ++++++++++++++
src/tracker-extract/tracker-extract.c | 19 +++++++++++++++++++
2 files changed, 33 insertions(+), 0 deletions(-)
---
diff --git a/src/tracker-extract/tracker-controller.c b/src/tracker-extract/tracker-controller.c
index 6c059fc..a2b0a0f 100644
--- a/src/tracker-extract/tracker-controller.c
+++ b/src/tracker-extract/tracker-controller.c
@@ -991,10 +991,24 @@ tracker_controller_start (TrackerController *controller,
{
TrackerControllerPrivate *priv;
+#if GLIB_CHECK_VERSION (2,31,0)
+ GThread *thread;
+
+ thread = g_thread_try_new ("controller",
+ tracker_controller_thread_func,
+ controller,
+ error);
+ if (!thread)
+ return FALSE;
+
+ /* We don't want to join it, so just unref the GThread */
+ g_thread_unref (thread);
+#else
if (!g_thread_create (tracker_controller_thread_func,
controller, FALSE, error)) {
return FALSE;
}
+#endif
priv = controller->priv;
diff --git a/src/tracker-extract/tracker-extract.c b/src/tracker-extract/tracker-extract.c
index ce78e1b..91b1d32 100644
--- a/src/tracker-extract/tracker-extract.c
+++ b/src/tracker-extract/tracker-extract.c
@@ -732,6 +732,24 @@ dispatch_task_cb (TrackerExtractTask *task)
*/
async_queue = g_async_queue_new ();
+#if GLIB_CHECK_VERSION (2,31,0)
+ {
+ GThread *thread;
+
+ thread = g_thread_try_new ("single",
+ (GThreadFunc) single_thread_get_metadata,
+ g_async_queue_ref (async_queue),
+ &error);
+ if (!thread) {
+ g_simple_async_result_take_error ((GSimpleAsyncResult *) task->res, error);
+ g_simple_async_result_complete_in_idle ((GSimpleAsyncResult *) task->res);
+ extract_task_free (task);
+ return FALSE;
+ }
+ /* We won't join the thread, so just unref it here */
+ g_object_unref (thread);
+ }
+#else
g_thread_create ((GThreadFunc) single_thread_get_metadata,
g_async_queue_ref (async_queue),
FALSE, &error);
@@ -744,6 +762,7 @@ dispatch_task_cb (TrackerExtractTask *task)
return FALSE;
}
+#endif
g_hash_table_insert (priv->single_thread_extractors, module, async_queue);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]