[tracker/class-signal] tracker-store, libtracker-data: class-signal: Cut at transaction, don't reset
- From: Philip Van Hoof <pvanhoof src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/class-signal] tracker-store, libtracker-data: class-signal: Cut at transaction, don't reset
- Date: Fri, 20 Aug 2010 17:14:15 +0000 (UTC)
commit 36fd5a86cb39f1e2e10b66a75d390baafa0b9d66
Author: Philip Van Hoof <philip codeminded be>
Date: Fri Aug 20 19:13:45 2010 +0200
tracker-store, libtracker-data: class-signal: Cut at transaction, don't reset
src/libtracker-data/tracker-class.c | 18 ++++++++++++++++++
src/libtracker-data/tracker-class.h | 1 +
src/tracker-store/tracker-events.c | 5 +++--
src/tracker-store/tracker-resources.c | 11 ++++++++++-
4 files changed, 32 insertions(+), 3 deletions(-)
---
diff --git a/src/libtracker-data/tracker-class.c b/src/libtracker-data/tracker-class.c
index 676d268..f78c6d9 100644
--- a/src/libtracker-data/tracker-class.c
+++ b/src/libtracker-data/tracker-class.c
@@ -526,6 +526,24 @@ tracker_class_reset_events (TrackerClass *class)
TrackerClassPrivate *priv;
g_return_if_fail (TRACKER_IS_CLASS (class));
+
+ priv = GET_PRIV (class);
+
+ /* Reset */
+ g_array_set_size (priv->deletes.ready.sub_pred_ids, 0);
+ g_array_set_size (priv->deletes.ready.object_ids, 0);
+
+ g_array_set_size (priv->inserts.ready.sub_pred_ids, 0);
+ g_array_set_size (priv->inserts.ready.object_ids, 0);
+
+}
+
+void
+tracker_class_transact_events (TrackerClass *class)
+{
+ TrackerClassPrivate *priv;
+
+ g_return_if_fail (TRACKER_IS_CLASS (class));
priv = GET_PRIV (class);
/* Move */
diff --git a/src/libtracker-data/tracker-class.h b/src/libtracker-data/tracker-class.h
index d3e3fbe..261dab8 100644
--- a/src/libtracker-data/tracker-class.h
+++ b/src/libtracker-data/tracker-class.h
@@ -99,6 +99,7 @@ void tracker_class_foreach_insert_event (TrackerClass *cla
gboolean tracker_class_has_insert_events (TrackerClass *class);
gboolean tracker_class_has_delete_events (TrackerClass *class);
void tracker_class_reset_events (TrackerClass *class);
+void tracker_class_transact_events (TrackerClass *class);
void tracker_class_add_delete_event (TrackerClass *class,
gint subject_id,
gint pred_id,
diff --git a/src/tracker-store/tracker-events.c b/src/tracker-store/tracker-events.c
index 042eaf8..33c1c2b 100644
--- a/src/tracker-store/tracker-events.c
+++ b/src/tracker-store/tracker-events.c
@@ -173,7 +173,8 @@ tracker_events_reset (void)
gpointer key, value;
g_return_if_fail (private != NULL);
-
+/*
+ this is wrong atm, check tracker-store.c what the purpose of this is
g_hash_table_iter_init (&iter, private->allowances);
while (g_hash_table_iter_next (&iter, &key, &value)) {
@@ -181,7 +182,7 @@ tracker_events_reset (void)
tracker_class_reset_events (class);
}
-
+*/
private->frozen = FALSE;
}
diff --git a/src/tracker-store/tracker-resources.c b/src/tracker-store/tracker-resources.c
index 0d8a15f..d9a0b65 100644
--- a/src/tracker-store/tracker-resources.c
+++ b/src/tracker-store/tracker-resources.c
@@ -617,11 +617,20 @@ on_statements_committed (gpointer user_data)
TrackerResources *resources = user_data;
GHashTable *writebacks;
TrackerResourcesPrivate *priv;
+ GHashTableIter iter;
+ gpointer key, value;
+
+ /* Class signal feature */
priv = TRACKER_RESOURCES_GET_PRIVATE (resources);
/* Class signal feature */
- tracker_events_reset ();
+ tracker_events_classes_iter (&iter);
+
+ while (g_hash_table_iter_next (&iter, &key, &value)) {
+ TrackerClass *class = key;
+ tracker_class_transact_events (class);
+ }
/* Writeback feature */
writebacks = tracker_writeback_get_pending ();
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]