[tracker/miner-fs-monitor-improvements: 1/4] libtracker-miner: Fire CREATED event only on CHANGES_DONE_HINT
- From: Aleksander Morgado <aleksm src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/miner-fs-monitor-improvements: 1/4] libtracker-miner: Fire CREATED event only on CHANGES_DONE_HINT
- Date: Tue, 21 Sep 2010 11:22:43 +0000 (UTC)
commit ac791b20fd9c3456db297bd51f880563bcc71852
Author: Aleksander Morgado <aleksander lanedo com>
Date: Mon Sep 20 18:35:13 2010 +0200
libtracker-miner: Fire CREATED event only on CHANGES_DONE_HINT
src/libtracker-miner/tracker-monitor.c | 32 +++++++++++++++++++++++---------
1 files changed, 23 insertions(+), 9 deletions(-)
---
diff --git a/src/libtracker-miner/tracker-monitor.c b/src/libtracker-miner/tracker-monitor.c
index 8b5396c..bb44fdc 100644
--- a/src/libtracker-miner/tracker-monitor.c
+++ b/src/libtracker-miner/tracker-monitor.c
@@ -821,23 +821,37 @@ monitor_event_cb (GFileMonitor *file_monitor,
/* Get previous event data, if any */
previous_update_event_data = g_hash_table_lookup (monitor->private->pre_update, file);
- /* If there is a previous ATTRIBUTE_CHANGED still not notified,
- * remove it, as we know there will be a CHANGES_DONE_HINT afterwards
- */
- if (previous_update_event_data &&
- previous_update_event_data->event_type == G_FILE_MONITOR_EVENT_ATTRIBUTE_CHANGED) {
- g_hash_table_remove (monitor->private->pre_update, file);
+ if (previous_update_event_data) {
+ if (previous_update_event_data->event_type == G_FILE_MONITOR_EVENT_ATTRIBUTE_CHANGED) {
+ /* If there is a previous ATTRIBUTE_CHANGED still not notified,
+ * remove it, as we know there will be a CHANGES_DONE_HINT afterwards
+ */
+ g_hash_table_remove (monitor->private->pre_update, file);
+ } else if (previous_update_event_data->event_type == G_FILE_MONITOR_EVENT_CREATED) {
+ /* Update the start_time of the original CREATED event that we're refreshing until
+ * there is a CHANGES_DONE_HINT. */
+ g_get_current_time (&(previous_update_event_data->start_time));
+ }
+ break;
}
-
- break;
}
} /* Else, Fall through and treat as an ATTRIBUTE_CHANGED */
case G_FILE_MONITOR_EVENT_ATTRIBUTE_CHANGED: {
- if (!g_hash_table_lookup (monitor->private->pre_update, file)) {
+ EventData *previous_update_event_data;
+
+ /* Get previous event data, if any */
+ previous_update_event_data = g_hash_table_lookup (monitor->private->pre_update, file);
+ if (!previous_update_event_data) {
+ /* If no previous one, insert it */
g_hash_table_insert (monitor->private->pre_update,
g_object_ref (file),
event_data_new (file, NULL, FALSE, event_type));
+ } else {
+ /* Update the start_time of the previous one.
+ * This could be the original CREATED event that we're refreshing until
+ * there is a CHANGES_DONE_HINT. */
+ g_get_current_time (&(previous_update_event_data->start_time));
}
break;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]