[tracker] libtracker-data: Use ontology journal for replay
- From: Philip Van Hoof <pvanhoof src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker] libtracker-data: Use ontology journal for replay
- Date: Mon, 25 Oct 2010 12:53:17 +0000 (UTC)
commit 126cf83fee4275538f77b3b45ebdd98d6cb8ebb7
Author: Jürg Billeter <j bitron ch>
Date: Wed Oct 6 12:49:40 2010 +0200
libtracker-data: Use ontology journal for replay
src/libtracker-data/tracker-data-manager.c | 123 +++++---------
src/libtracker-data/tracker-data-update.c | 244 +---------------------------
src/libtracker-data/tracker-data-update.h | 5 +-
src/libtracker-data/tracker-db-journal.c | 23 +++
src/libtracker-data/tracker-db-journal.h | 1 +
5 files changed, 75 insertions(+), 321 deletions(-)
---
diff --git a/src/libtracker-data/tracker-data-manager.c b/src/libtracker-data/tracker-data-manager.c
index 92f087f..f7c3b86 100644
--- a/src/libtracker-data/tracker-data-manager.c
+++ b/src/libtracker-data/tracker-data-manager.c
@@ -1123,7 +1123,8 @@ load_ontology_file_from_path (const gchar *ontology_path,
gint *max_id,
gboolean in_update,
GPtrArray *seen_classes,
- GPtrArray *seen_properties)
+ GPtrArray *seen_properties,
+ GHashTable *uri_id_map)
{
TrackerTurtleReader *reader;
GError *error = NULL;
@@ -1140,11 +1141,16 @@ load_ontology_file_from_path (const gchar *ontology_path,
while (error == NULL && tracker_turtle_reader_next (reader, &error)) {
const gchar *subject, *predicate, *object;
+ gint subject_id;
subject = tracker_turtle_reader_get_subject (reader);
predicate = tracker_turtle_reader_get_predicate (reader);
object = tracker_turtle_reader_get_object (reader);
+ if (uri_id_map) {
+ subject_id = GPOINTER_TO_INT (g_hash_table_lookup (uri_id_map, subject));
+ }
+
tracker_data_ontology_load_statement (ontology_path, 0, subject, predicate, object,
max_id, in_update, NULL, NULL,
seen_classes, seen_properties);
@@ -1230,21 +1236,12 @@ get_ontology_from_path (const gchar *ontology_path)
}
static void
-load_ontology_from_journal (GHashTable **classes_out,
- GHashTable **properties_out,
- GHashTable **id_uri_map_out)
+load_ontology_ids_from_journal (GHashTable **uri_id_map_out)
{
- GHashTable *id_uri_map;
- GHashTable *classes, *properties;
-
- classes = g_hash_table_new_full (g_direct_hash, g_direct_equal,
- NULL, (GDestroyNotify) g_object_unref);
+ GHashTable *uri_id_map;
- properties = g_hash_table_new_full (g_direct_hash, g_direct_equal,
- NULL, (GDestroyNotify) g_object_unref);
-
- id_uri_map = g_hash_table_new_full (g_direct_hash, g_direct_equal,
- NULL, g_free);
+ uri_id_map = g_hash_table_new_full (g_str_hash, g_str_equal,
+ g_free, NULL);
while (tracker_db_journal_reader_next (NULL)) {
TrackerDBJournalEntryType type;
@@ -1255,38 +1252,11 @@ load_ontology_from_journal (GHashTable **classes_out,
const gchar *uri;
tracker_db_journal_reader_get_resource (&id, &uri);
- g_hash_table_insert (id_uri_map, GINT_TO_POINTER (id), g_strdup (uri));
- } else if (type == TRACKER_DB_JOURNAL_END_TRANSACTION) {
- /* end of initial transaction => end of ontology */
- break;
- } else {
- const gchar *subject, *predicate, *object;
- gint subject_id, predicate_id, object_id;
-
- if (type == TRACKER_DB_JOURNAL_INSERT_STATEMENT) {
- tracker_db_journal_reader_get_statement (NULL, &subject_id, &predicate_id, &object);
- } else if (type == TRACKER_DB_JOURNAL_INSERT_STATEMENT_ID) {
- tracker_db_journal_reader_get_statement_id (NULL, &subject_id, &predicate_id, &object_id);
- object = g_hash_table_lookup (id_uri_map, GINT_TO_POINTER (object_id));
- } else {
- continue;
- }
-
- subject = g_hash_table_lookup (id_uri_map, GINT_TO_POINTER (subject_id));
- predicate = g_hash_table_lookup (id_uri_map, GINT_TO_POINTER (predicate_id));
-
- /* Post checks are only needed for ontology updates, not the initial
- * ontology */
-
- tracker_data_ontology_load_statement ("journal", subject_id, subject, predicate,
- object, NULL, FALSE, classes, properties,
- NULL, NULL);
+ g_hash_table_insert (uri_id_map, g_strdup (uri), GINT_TO_POINTER (id));
}
}
- *classes_out = classes;
- *properties_out = properties;
- *id_uri_map_out = id_uri_map;
+ *uri_id_map_out = uri_id_map;
}
void
@@ -2774,6 +2744,7 @@ tracker_data_manager_init (TrackerDBManagerFlags flags,
const gchar *env_path;
gint max_id = 0;
gboolean read_only;
+ GHashTable *uri_id_map = NULL;
tracker_data_update_init ();
@@ -2815,9 +2786,8 @@ tracker_data_manager_init (TrackerDBManagerFlags flags,
/* journal with at least one valid transaction
is required to trigger journal replay */
read_journal = TRUE;
- } else {
- tracker_db_journal_reader_shutdown ();
}
+ tracker_db_journal_reader_shutdown ();
}
}
@@ -2833,46 +2803,24 @@ tracker_data_manager_init (TrackerDBManagerFlags flags,
}
if (read_journal) {
- GHashTable *classes = NULL, *properties = NULL;
- GHashTable *id_uri_map = NULL;
-
in_journal_replay = TRUE;
- /* Load ontology from journal into memory and cache ID v. uri mappings */
- load_ontology_from_journal (&classes, &properties, &id_uri_map);
+ tracker_db_journal_reader_ontology_init (NULL);
- /* Read first ontology and commit it into the DB */
- tracker_data_begin_transaction_for_replay (tracker_db_journal_reader_get_time (), NULL);
-
- /* This is a no-op when FTS is disabled */
- tracker_db_interface_sqlite_fts_init (iface, TRUE);
+ /* Load ontology IDs from journal into memory */
+ load_ontology_ids_from_journal (&uri_id_map);
- tracker_data_ontology_import_into_db (FALSE);
- tracker_data_commit_transaction (NULL);
tracker_db_journal_reader_shutdown ();
+ }
- /* Start replay. Ontology changes might happen during replay of the journal. */
-
- tracker_data_replay_journal (classes, properties, id_uri_map,
- busy_callback, busy_user_data, busy_status);
-
- in_journal_replay = FALSE;
-
- /* open journal for writing */
- tracker_db_journal_init (NULL, FALSE);
-
- check_ontology = TRUE;
-
- g_hash_table_unref (classes);
- g_hash_table_unref (properties);
- g_hash_table_unref (id_uri_map);
-
- } else if (is_first_time_index && !read_only) {
+ if (is_first_time_index && !read_only) {
sorted = get_ontologies (test_schemas != NULL, ontologies_dir);
- /* Truncate journal as it does not even contain a single valid transaction
- * or is explicitly ignored (journal_check == FALSE, only for test cases) */
- tracker_db_journal_init (NULL, TRUE);
+ if (!read_journal) {
+ /* Truncate journal as it does not even contain a single valid transaction
+ * or is explicitly ignored (journal_check == FALSE, only for test cases) */
+ tracker_db_journal_init (NULL, TRUE);
+ }
/* load ontology from files into memory (max_id starts at zero: first-time) */
@@ -2880,7 +2828,7 @@ tracker_data_manager_init (TrackerDBManagerFlags flags,
gchar *ontology_path;
g_debug ("Loading ontology %s", (char *) l->data);
ontology_path = g_build_filename (ontologies_dir, l->data, NULL);
- load_ontology_file_from_path (ontology_path, &max_id, FALSE, NULL, NULL);
+ load_ontology_file_from_path (ontology_path, &max_id, FALSE, NULL, NULL, uri_id_map);
g_free (ontology_path);
}
@@ -2892,7 +2840,7 @@ tracker_data_manager_init (TrackerDBManagerFlags flags,
g_debug ("Loading ontology:'%s' (TEST ONTOLOGY)", test_schema_path);
- load_ontology_file_from_path (test_schema_path, &max_id, FALSE, NULL, NULL);
+ load_ontology_file_from_path (test_schema_path, &max_id, FALSE, NULL, NULL, uri_id_map);
g_free (test_schema_path);
}
}
@@ -3060,7 +3008,7 @@ tracker_data_manager_init (TrackerDBManagerFlags flags,
/* load ontology from files into memory, set all new's
* is_new to TRUE */
load_ontology_file_from_path (ontology_path, &max_id, TRUE,
- seen_classes, seen_properties);
+ seen_classes, seen_properties, uri_id_map);
to_reload = g_list_prepend (to_reload, l->data);
update_nao = TRUE;
}
@@ -3073,7 +3021,7 @@ tracker_data_manager_init (TrackerDBManagerFlags flags,
/* load ontology from files into memory, set all new's
* is_new to TRUE */
load_ontology_file_from_path (ontology_path, &max_id, TRUE,
- seen_classes, seen_properties);
+ seen_classes, seen_properties, uri_id_map);
to_reload = g_list_prepend (to_reload, l->data);
update_nao = TRUE;
}
@@ -3136,6 +3084,19 @@ tracker_data_manager_init (TrackerDBManagerFlags flags,
g_list_free (ontos);
}
+ if (read_journal) {
+ /* Start replay */
+
+ tracker_data_replay_journal (busy_callback, busy_user_data, busy_status);
+
+ in_journal_replay = FALSE;
+
+ /* open journal for writing */
+ tracker_db_journal_init (NULL, FALSE);
+
+ g_hash_table_unref (uri_id_map);
+ }
+
/* If locale changed, re-create indexes */
if (!read_only && tracker_db_manager_locale_changed ()) {
tracker_data_manager_recreate_indexes ();
diff --git a/src/libtracker-data/tracker-data-update.c b/src/libtracker-data/tracker-data-update.c
index cea2baf..5df0414 100644
--- a/src/libtracker-data/tracker-data-update.c
+++ b/src/libtracker-data/tracker-data-update.c
@@ -2699,161 +2699,14 @@ tracker_data_sync (void)
tracker_db_journal_fsync ();
}
-static void
-free_queued_statement (QueuedStatement *queued)
-{
- g_free (queued->subject);
- g_free (queued->predicate);
- g_free (queued->object);
- g_free (queued->graph);
- g_free (queued);
-}
-
-static GList*
-queue_statement (GList *queue,
- const gchar *graph,
- const gchar *subject,
- const gchar *predicate,
- const gchar *object,
- gboolean is_uri)
-{
- QueuedStatement *queued = g_new (QueuedStatement, 1);
-
- queued->subject = g_strdup (subject);
- queued->predicate = g_strdup (predicate);
- queued->object = g_strdup (object);
- queued->is_uri = is_uri;
- queued->graph = graph ? g_strdup (graph) : NULL;
-
- queue = g_list_append (queue, queued);
-
- return queue;
-}
-
-static void
-ontology_transaction_end (GList *ontology_queue,
- GPtrArray *seen_classes,
- GPtrArray *seen_properties)
-{
- GList *l;
- const gchar *ontology_uri = NULL;
-
- tracker_data_ontology_process_changes_pre_db (seen_classes, seen_properties);
-
- /* Perform ALTER-TABLE and CREATE-TABLE calls for all that are is_new */
- tracker_data_ontology_import_into_db (TRUE);
-
- tracker_data_ontology_process_changes_post_db (seen_classes, seen_properties);
-
- for (l = ontology_queue; l; l = l->next) {
- QueuedStatement *queued = ontology_queue->data;
-
- if (g_strcmp0 (queued->predicate, RDF_TYPE) == 0) {
- if (g_strcmp0 (queued->object, TRACKER_PREFIX "Ontology") == 0) {
- ontology_uri = queued->subject;
- }
- }
-
- /* store ontology in database */
- tracker_data_ontology_process_statement (queued->graph,
- queued->subject,
- queued->predicate,
- queued->object,
- queued->is_uri,
- TRUE, TRUE);
-
- }
-
- tracker_data_ontology_process_changes_post_import (seen_classes, seen_properties);
-
- /* Update the nao:lastModified in the database */
- if (ontology_uri) {
- TrackerOntology *ontology;
- ontology = tracker_ontologies_get_ontology_by_uri (ontology_uri);
- if (ontology) {
- gint last_mod = 0;
- TrackerDBInterface *iface;
- TrackerDBStatement *stmt;
- GError *error = NULL;
-
- iface = tracker_db_manager_get_db_interface ();
-
- /* We can't do better than this cast, it's stored as an int in the
- * db. See tracker-data-manager.c for more info. */
- last_mod = (gint) tracker_ontology_get_last_modified (ontology);
-
- stmt = tracker_db_interface_create_statement (iface, TRACKER_DB_STATEMENT_CACHE_TYPE_UPDATE, &error,
- "UPDATE \"rdfs:Resource\" SET \"nao:lastModified\"= ? "
- "WHERE \"rdfs:Resource\".ID = "
- "(SELECT Resource.ID FROM Resource INNER JOIN \"rdfs:Resource\" "
- "ON \"rdfs:Resource\".ID = Resource.ID WHERE "
- "Resource.Uri = ?)");
-
- if (stmt) {
- tracker_db_statement_bind_int (stmt, 0, last_mod);
- tracker_db_statement_bind_text (stmt, 1, ontology_uri);
- tracker_db_statement_execute (stmt, NULL);
- } else {
- g_warning ("%s", error->message);
- g_error_free (error);
- }
- }
- }
-
- /* Reset the is_new flag for all classes and properties */
- tracker_data_ontology_import_finished ();
-}
-
-static GList*
-ontology_statement_insert (GList *ontology_queue,
- gint graph_id,
- gint subject_id,
- gint predicate_id,
- const gchar *object,
- GHashTable *classes,
- GHashTable *properties,
- GHashTable *id_uri_map,
- gboolean is_uri,
- GPtrArray *seen_classes,
- GPtrArray *seen_properties)
-{
- const gchar *graph, *subject, *predicate;
-
- if (graph_id > 0) {
- graph = g_hash_table_lookup (id_uri_map, GINT_TO_POINTER (graph_id));
- } else {
- graph = NULL;
- }
-
- subject = g_hash_table_lookup (id_uri_map, GINT_TO_POINTER (subject_id));
- predicate = g_hash_table_lookup (id_uri_map, GINT_TO_POINTER (predicate_id));
-
- /* load ontology from journal into memory, set all new's is_new to TRUE */
- tracker_data_ontology_load_statement ("journal", subject_id, subject, predicate,
- object, NULL, TRUE, classes, properties,
- seen_classes, seen_properties);
-
- /* Queue the statement for processing after ALTER in ontology_transaction_end */
- ontology_queue = queue_statement (ontology_queue, graph, subject, predicate, object, is_uri);
-
- return ontology_queue;
-}
-
void
-tracker_data_replay_journal (GHashTable *classes,
- GHashTable *properties,
- GHashTable *id_uri_map,
- TrackerBusyCallback busy_callback,
+tracker_data_replay_journal (TrackerBusyCallback busy_callback,
gpointer busy_user_data,
const gchar *busy_status)
{
GError *journal_error = NULL;
TrackerProperty *rdf_type = NULL;
gint last_operation_type = 0;
- gboolean in_ontology = FALSE;
- GList *ontology_queue = NULL;
- GPtrArray *seen_classes = NULL;
- GPtrArray *seen_properties = NULL;
rdf_type = tracker_ontologies_get_rdf_type ();
@@ -2871,23 +2724,9 @@ tracker_data_replay_journal (GHashTable *classes,
TrackerDBStatement *stmt;
gint id;
const gchar *uri;
- TrackerProperty *property = NULL;
- TrackerClass *class;
tracker_db_journal_reader_get_resource (&id, &uri);
- if (in_ontology) {
- g_hash_table_insert (id_uri_map, GINT_TO_POINTER (id), g_strdup (uri));
- continue;
- }
-
- class = g_hash_table_lookup (classes, GINT_TO_POINTER (id));
- if (!class)
- property = g_hash_table_lookup (properties, GINT_TO_POINTER (id));
-
- if (property || class)
- continue;
-
iface = tracker_db_manager_get_db_interface ();
stmt = tracker_db_interface_create_statement (iface, TRACKER_DB_STATEMENT_CACHE_TYPE_UPDATE, &new_error,
@@ -2908,27 +2747,12 @@ tracker_data_replay_journal (GHashTable *classes,
g_error_free (new_error);
}
- } else if (type == TRACKER_DB_JOURNAL_START_ONTOLOGY_TRANSACTION) {
- tracker_data_begin_transaction_for_replay (tracker_db_journal_reader_get_time (), NULL);
- in_ontology = TRUE;
} else if (type == TRACKER_DB_JOURNAL_START_TRANSACTION) {
tracker_data_begin_transaction_for_replay (tracker_db_journal_reader_get_time (), NULL);
} else if (type == TRACKER_DB_JOURNAL_END_TRANSACTION) {
GError *new_error = NULL;
tracker_data_update_buffer_might_flush (&new_error);
- if (in_ontology) {
- ontology_transaction_end (ontology_queue, seen_classes, seen_properties);
- g_list_foreach (ontology_queue, (GFunc) free_queued_statement, NULL);
- g_list_free (ontology_queue);
- ontology_queue = NULL;
- in_ontology = FALSE;
- tracker_data_ontology_free_seen (seen_classes);
- seen_classes = NULL;
- tracker_data_ontology_free_seen (seen_properties);
- seen_properties = NULL;
- }
-
tracker_data_commit_transaction (&new_error);
if (new_error) {
g_warning ("Journal replay error: '%s'", new_error->message);
@@ -2940,27 +2764,6 @@ tracker_data_replay_journal (GHashTable *classes,
tracker_db_journal_reader_get_statement (&graph_id, &subject_id, &predicate_id, &object);
- if (in_ontology) {
-
- if (!seen_classes)
- seen_classes = g_ptr_array_new ();
- if (!seen_properties)
- seen_properties = g_ptr_array_new ();
-
- ontology_queue = ontology_statement_insert (ontology_queue,
- graph_id,
- subject_id,
- predicate_id,
- object,
- classes,
- properties,
- id_uri_map,
- FALSE,
- seen_classes,
- seen_properties);
- continue;
- }
-
if (last_operation_type == -1) {
tracker_data_update_buffer_flush (&new_error);
if (new_error) {
@@ -2970,7 +2773,7 @@ tracker_data_replay_journal (GHashTable *classes,
}
last_operation_type = 1;
- property = g_hash_table_lookup (properties, GINT_TO_POINTER (predicate_id));
+ property = tracker_ontologies_get_property_by_uri (tracker_ontologies_get_uri_by_id (predicate_id));
if (property) {
resource_buffer_switch (NULL, graph_id, NULL, subject_id);
@@ -2993,29 +2796,6 @@ tracker_data_replay_journal (GHashTable *classes,
tracker_db_journal_reader_get_statement_id (&graph_id, &subject_id, &predicate_id, &object_id);
- if (in_ontology) {
- const gchar *object_n;
- object_n = g_hash_table_lookup (id_uri_map, GINT_TO_POINTER (object_id));
-
- if (!seen_classes)
- seen_classes = g_ptr_array_new ();
- if (!seen_properties)
- seen_properties = g_ptr_array_new ();
-
- ontology_queue = ontology_statement_insert (ontology_queue,
- graph_id,
- subject_id,
- predicate_id,
- object_n,
- classes,
- properties,
- id_uri_map,
- TRUE,
- seen_classes,
- seen_properties);
- continue;
- }
-
if (last_operation_type == -1) {
tracker_data_update_buffer_flush (&new_error);
if (new_error) {
@@ -3025,7 +2805,7 @@ tracker_data_replay_journal (GHashTable *classes,
}
last_operation_type = 1;
- property = g_hash_table_lookup (properties, GINT_TO_POINTER (predicate_id));
+ property = tracker_ontologies_get_property_by_uri (tracker_ontologies_get_uri_by_id (predicate_id));
if (property) {
if (tracker_property_get_data_type (property) != TRACKER_PROPERTY_TYPE_RESOURCE) {
@@ -3034,7 +2814,7 @@ tracker_data_replay_journal (GHashTable *classes,
resource_buffer_switch (NULL, graph_id, NULL, subject_id);
if (property == rdf_type) {
- class = g_hash_table_lookup (classes, GINT_TO_POINTER (object_id));
+ class = tracker_ontologies_get_class_by_uri (tracker_ontologies_get_uri_by_id (object_id));
if (class) {
cache_create_service_decomposed (class, NULL, graph_id);
} else {
@@ -3062,10 +2842,6 @@ tracker_data_replay_journal (GHashTable *classes,
tracker_db_journal_reader_get_statement (&graph_id, &subject_id, &predicate_id, &object);
- if (in_ontology) {
- continue;
- }
-
if (last_operation_type == 1) {
tracker_data_update_buffer_flush (&new_error);
if (new_error) {
@@ -3077,7 +2853,7 @@ tracker_data_replay_journal (GHashTable *classes,
resource_buffer_switch (NULL, graph_id, NULL, subject_id);
- property = g_hash_table_lookup (properties, GINT_TO_POINTER (predicate_id));
+ property = tracker_ontologies_get_property_by_uri (tracker_ontologies_get_uri_by_id (predicate_id));
if (property) {
GError *new_error = NULL;
@@ -3085,7 +2861,7 @@ tracker_data_replay_journal (GHashTable *classes,
if (object && rdf_type == property) {
TrackerClass *class;
- class = tracker_ontologies_get_class_by_uri (object);
+ class = tracker_ontologies_get_class_by_uri (tracker_ontologies_get_uri_by_id (object_id));
if (class != NULL) {
cache_delete_resource_type (class, NULL, graph_id);
} else {
@@ -3111,10 +2887,6 @@ tracker_data_replay_journal (GHashTable *classes,
tracker_db_journal_reader_get_statement_id (&graph_id, &subject_id, &predicate_id, &object_id);
- if (in_ontology) {
- continue;
- }
-
if (last_operation_type == 1) {
tracker_data_update_buffer_flush (&new_error);
if (new_error) {
@@ -3124,14 +2896,14 @@ tracker_data_replay_journal (GHashTable *classes,
}
last_operation_type = -1;
- property = g_hash_table_lookup (properties, GINT_TO_POINTER (predicate_id));
+ property = tracker_ontologies_get_property_by_uri (tracker_ontologies_get_uri_by_id (predicate_id));
if (property) {
resource_buffer_switch (NULL, graph_id, NULL, subject_id);
if (property == rdf_type) {
- class = g_hash_table_lookup (classes, GINT_TO_POINTER (object_id));
+ class = tracker_ontologies_get_class_by_uri (tracker_ontologies_get_uri_by_id (object_id));
if (class) {
cache_delete_resource_type (class, NULL, graph_id);
} else {
diff --git a/src/libtracker-data/tracker-data-update.h b/src/libtracker-data/tracker-data-update.h
index de552d4..343674f 100644
--- a/src/libtracker-data/tracker-data-update.h
+++ b/src/libtracker-data/tracker-data-update.h
@@ -89,10 +89,7 @@ void tracker_data_load_turtle_file (GFile *
GError **error);
void tracker_data_sync (void);
-void tracker_data_replay_journal (GHashTable *classes,
- GHashTable *properties,
- GHashTable *id_uri_map,
- TrackerBusyCallback busy_callback,
+void tracker_data_replay_journal (TrackerBusyCallback busy_callback,
gpointer busy_user_data,
const gchar *busy_status);
diff --git a/src/libtracker-data/tracker-db-journal.c b/src/libtracker-data/tracker-db-journal.c
index f92af08..8fb0a48 100644
--- a/src/libtracker-data/tracker-db-journal.c
+++ b/src/libtracker-data/tracker-db-journal.c
@@ -1208,6 +1208,29 @@ tracker_db_journal_reader_init (const gchar *filename)
return db_journal_reader_init (&reader, TRUE, filename);
}
+gboolean
+tracker_db_journal_reader_ontology_init (const gchar *filename) {
+ gchar *filename_used;
+ gboolean result;
+
+ /* Used mostly for testing */
+ if (G_UNLIKELY (filename)) {
+ filename_used = g_strdup (filename);
+ } else {
+ filename_used = g_build_filename (g_get_user_data_dir (),
+ "tracker",
+ "data",
+ TRACKER_DB_JOURNAL_ONTOLOGY_FILENAME,
+ NULL);
+ }
+
+ result = tracker_db_journal_reader_init (filename_used);
+
+ g_free (filename_used);
+
+ return result;
+}
+
gsize
tracker_db_journal_reader_get_size_of_correct (void)
{
diff --git a/src/libtracker-data/tracker-db-journal.h b/src/libtracker-data/tracker-db-journal.h
index 71ec08b..149f360 100644
--- a/src/libtracker-data/tracker-db-journal.h
+++ b/src/libtracker-data/tracker-db-journal.h
@@ -96,6 +96,7 @@ gboolean tracker_db_journal_truncate (gsize new_size);
* Reader API
*/
gboolean tracker_db_journal_reader_init (const gchar *filename);
+gboolean tracker_db_journal_reader_ontology_init (const gchar *filename);
gboolean tracker_db_journal_reader_shutdown (void);
TrackerDBJournalEntryType
tracker_db_journal_reader_get_type (void);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]