[tracker/writeback-refactor-rebase: 33/43] libtracker-miner: Separate writeback tasks to their own task pool
- From: Philip Van Hoof <pvanhoof src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/writeback-refactor-rebase: 33/43] libtracker-miner: Separate writeback tasks to their own task pool
- Date: Tue, 26 Jul 2011 09:33:37 +0000 (UTC)
commit 2ecfcd0c6f0069ee49744b83fc100587ca8f36e3
Author: Carlos Garnacho <carlos lanedo com>
Date: Wed Jul 20 15:49:26 2011 +0200
libtracker-miner: Separate writeback tasks to their own task pool
Tasks now have a gboolean* as the data, indicating whether the task
was already notified or not, the code hooking to the monitor events
has been modified so the UPDATED event needs to happen on a notified
file in order to consider the writeback task finished.
src/libtracker-miner/tracker-miner-fs.c | 76 ++++++++++++++++++++-----------
1 files changed, 50 insertions(+), 26 deletions(-)
---
diff --git a/src/libtracker-miner/tracker-miner-fs.c b/src/libtracker-miner/tracker-miner-fs.c
index d79d234..dbca1e6 100644
--- a/src/libtracker-miner/tracker-miner-fs.c
+++ b/src/libtracker-miner/tracker-miner-fs.c
@@ -211,6 +211,9 @@ struct _TrackerMinerFSPrivate {
/* Extraction tasks */
TrackerTaskPool *task_pool;
+ /* Writeback tasks */
+ TrackerTaskPool *writeback_pool;
+
/* Sparql insertion tasks */
TrackerSparqlBuffer *sparql_buffer;
guint sparql_buffer_limit;
@@ -731,6 +734,7 @@ tracker_miner_fs_init (TrackerMinerFS *object)
/* Create processing pools */
priv->task_pool = tracker_task_pool_new (DEFAULT_WAIT_POOL_LIMIT);
+ priv->writeback_pool = tracker_task_pool_new (DEFAULT_WAIT_POOL_LIMIT);
/* Set up the crawlers now we have config and hal */
priv->crawler = tracker_crawler_new ();
@@ -864,6 +868,8 @@ fs_finalize (GObject *object)
NULL);
g_object_unref (priv->task_pool);
+ g_object_unref (priv->writeback_pool);
+
if (priv->sparql_buffer) {
g_object_unref (priv->sparql_buffer);
}
@@ -2506,6 +2512,7 @@ should_wait (TrackerMinerFS *fs,
/* Is the item already being processed? */
if (tracker_task_pool_find (fs->priv->task_pool, file) ||
+ tracker_task_pool_find (fs->priv->writeback_pool, file) ||
tracker_task_pool_find (TRACKER_TASK_POOL (fs->priv->sparql_buffer), file)) {
/* Yes, a previous event on same item currently
* being processed */
@@ -2557,9 +2564,20 @@ item_queue_get_next_file (TrackerMinerFS *fs,
wdata->results,
&processing);
- item_writeback_data_free (wdata);
+ if (processing) {
+ TrackerTask *task;
+ gboolean *notified;
- return (processing) ? QUEUE_WRITEBACK : QUEUE_NONE;
+ notified = g_new0 (gboolean, 1);
+ task = tracker_task_new (wdata->file, notified,
+ (GDestroyNotify) g_free);
+ tracker_task_pool_add (fs->priv->writeback_pool, task);
+
+ item_writeback_data_free (wdata);
+ return QUEUE_WRITEBACK;
+ } else {
+ item_writeback_data_free (wdata);
+ }
}
/* Deleted items second */
@@ -3041,16 +3059,9 @@ item_queue_handlers_cb (gpointer user_data)
case QUEUE_IGNORE_NEXT_UPDATE:
keep_processing = item_ignore_next_update (fs, file, source_file);
break;
- case QUEUE_WRITEBACK: {
- TrackerTask *task;
-
- /* The signal was emitted at an earlier stage,
- * so here we just add the task to the task pool
- */
- task = tracker_task_new (file, NULL, NULL);
- tracker_task_pool_add (fs->priv->task_pool, task);
+ case QUEUE_WRITEBACK:
+ /* Nothing to do here */
keep_processing = TRUE;
- }
break;
default:
g_assert_not_reached ();
@@ -3099,8 +3110,9 @@ item_queue_handlers_set_up (TrackerMinerFS *fs)
return;
}
- /* Already sent max number of tasks to tracker-extract? */
- if (tracker_task_pool_limit_reached (fs->priv->task_pool)) {
+ /* Already sent max number of tasks to tracker-extract/writeback? */
+ if (tracker_task_pool_limit_reached (fs->priv->task_pool) ||
+ tracker_task_pool_limit_reached (fs->priv->writeback_pool)) {
return;
}
@@ -3497,11 +3509,18 @@ remove_writeback_task (TrackerMinerFS *fs,
GFile *file)
{
TrackerTask *task;
+ gboolean *notified;
- task = tracker_task_pool_find (fs->priv->task_pool, file);
+ task = tracker_task_pool_find (fs->priv->writeback_pool, file);
- if (task && tracker_task_get_data (task) == NULL) {
- tracker_task_pool_remove (fs->priv->task_pool, task);
+ if (!task) {
+ return FALSE;
+ }
+
+ notified = tracker_task_get_data (task);
+
+ if (notified && *notified) {
+ tracker_task_pool_remove (fs->priv->writeback_pool, task);
tracker_task_unref (task);
return TRUE;
}
@@ -3533,12 +3552,12 @@ check_item_queues (TrackerMinerFS *fs,
TrackerTask *task;
if (other_file) {
- task = tracker_task_pool_find (fs->priv->task_pool, other_file);
+ task = tracker_task_pool_find (fs->priv->writeback_pool, other_file);
} else {
- task = tracker_task_pool_find (fs->priv->task_pool, file);
+ task = tracker_task_pool_find (fs->priv->writeback_pool, file);
}
- if (task && !tracker_task_get_data (task)) {
+ if (task) {
/* There is a writeback task for
* this file, so avoid any updates
*/
@@ -4511,11 +4530,6 @@ task_pool_cancel_foreach (gpointer data,
UpdateProcessingTaskContext *ctxt;
ctxt = tracker_task_get_data (task);
-
- if (!ctxt) {
- return;
- }
-
task_file = tracker_task_get_file (task);
if (ctxt &&
@@ -4818,7 +4832,7 @@ tracker_miner_fs_writeback_notify (TrackerMinerFS *fs,
fs->priv->total_files_notified++;
- task = tracker_task_pool_find (fs->priv->task_pool, file);
+ task = tracker_task_pool_find (fs->priv->writeback_pool, file);
if (!task) {
gchar *uri;
@@ -4838,8 +4852,18 @@ tracker_miner_fs_writeback_notify (TrackerMinerFS *fs,
/* We don't expect any further monitor
* events on the original file.
*/
- tracker_task_pool_remove (fs->priv->task_pool, task);
+ tracker_task_pool_remove (fs->priv->writeback_pool, task);
tracker_task_unref (task);
+
+ item_queue_handlers_set_up (fs);
+ } else {
+ gboolean *notified;
+
+ notified = tracker_task_get_data (task);
+
+ if (notified) {
+ *notified = TRUE;
+ }
}
/* Check monitor_item_updated_cb() for the remainder of this notify,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]