[tracker/miner-fs-refactor: 103/127] libtracker-miner: Cancel sparql query in TrackerFileNotifier when crawling stops
- From: Martyn James Russell <mr src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/miner-fs-refactor: 103/127] libtracker-miner: Cancel sparql query in TrackerFileNotifier when crawling stops
- Date: Wed, 7 Dec 2011 10:45:36 +0000 (UTC)
commit 512715e2f00d9ba2ec76851104f8ca782eee9327
Author: Carlos Garnacho <carlos lanedo com>
Date: Thu Oct 20 15:50:23 2011 +0200
libtracker-miner: Cancel sparql query in TrackerFileNotifier when crawling stops
src/libtracker-miner/tracker-file-notifier.c | 9 ++++++++-
1 files changed, 8 insertions(+), 1 deletions(-)
---
diff --git a/src/libtracker-miner/tracker-file-notifier.c b/src/libtracker-miner/tracker-file-notifier.c
index 3c433c8..5ac7761 100644
--- a/src/libtracker-miner/tracker-file-notifier.c
+++ b/src/libtracker-miner/tracker-file-notifier.c
@@ -58,6 +58,7 @@ typedef struct {
TrackerFileSystem *file_system;
TrackerSparqlConnection *connection;
+ GCancellable *cancellable;
TrackerCrawler *crawler;
TrackerMonitor *monitor;
@@ -520,7 +521,7 @@ sparql_file_query_start (TrackerFileNotifier *notifier,
} else {
tracker_sparql_connection_query_async (priv->connection,
sparql,
- NULL,
+ priv->cancellable,
sparql_query_cb,
notifier);
}
@@ -561,6 +562,8 @@ crawl_directories_start (TrackerFileNotifier *notifier)
directory,
quark_property_queried);
+ g_cancellable_reset (priv->cancellable);
+
if ((flags & TRACKER_DIRECTORY_FLAG_IGNORE) == 0 &&
tracker_crawler_start (priv->crawler,
directory,
@@ -1001,6 +1004,7 @@ indexing_tree_directory_removed (TrackerIndexingTree *indexing_tree,
directory == priv->pending_index_roots->data) {
/* Directory being currently processed */
tracker_crawler_stop (priv->crawler);
+ g_cancellable_cancel (priv->cancellable);
/* Remove index root and try the next one */
priv->pending_index_roots = g_list_delete_link (priv->pending_index_roots,
@@ -1030,6 +1034,7 @@ tracker_file_notifier_finalize (GObject *object)
g_object_unref (priv->crawler);
g_object_unref (priv->monitor);
g_object_unref (priv->file_system);
+ g_object_unref (priv->cancellable);
g_list_free (priv->pending_index_roots);
g_timer_destroy (priv->timer);
@@ -1176,6 +1181,7 @@ tracker_file_notifier_init (TrackerFileNotifier *notifier)
TrackerFileNotifierPrivate);
priv->connection = tracker_sparql_connection_get (NULL, &error);
+ priv->cancellable = g_cancellable_new ();
if (error) {
g_critical ("Could not get SPARQL connection: %s\n",
@@ -1270,6 +1276,7 @@ tracker_file_notifier_stop (TrackerFileNotifier *notifier)
if (!priv->stopped) {
tracker_crawler_stop (priv->crawler);
+ g_cancellable_cancel (priv->cancellable);
priv->stopped = TRUE;
}
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]