[tracker] libtracker-data: Write transactions in ontology journal
- From: Philip Van Hoof <pvanhoof src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker] libtracker-data: Write transactions in ontology journal
- Date: Mon, 25 Oct 2010 12:53:02 +0000 (UTC)
commit 1094aaba0c898a8fff1c641f508f3db71e48e750
Author: Jürg Billeter <j bitron ch>
Date: Tue Sep 28 15:50:20 2010 +0200
libtracker-data: Write transactions in ontology journal
src/libtracker-data/tracker-db-journal.c | 50 +++++++++++++++++++++++++++++-
src/libtracker-data/tracker-db-journal.h | 7 ++--
2 files changed, 53 insertions(+), 4 deletions(-)
---
diff --git a/src/libtracker-data/tracker-db-journal.c b/src/libtracker-data/tracker-db-journal.c
index 8a26ac4..040d668 100644
--- a/src/libtracker-data/tracker-db-journal.c
+++ b/src/libtracker-data/tracker-db-journal.c
@@ -62,6 +62,7 @@ typedef enum {
} DataFormat;
typedef enum {
+ TRANSACTION_FORMAT_NONE = 0,
TRANSACTION_FORMAT_DATA = 1 << 0,
TRANSACTION_FORMAT_ONTOLOGY = 1 << 1,
} TransactionFormat;
@@ -111,6 +112,9 @@ static struct {
static JournalReader reader = {0};
static JournalWriter writer = {0};
+static JournalWriter ontology_writer = {0};
+
+static TransactionFormat current_transaction_format;
#if GLIB_CHECK_VERSION (2, 24, 2)
static gboolean tracker_db_journal_rotate (void);
@@ -550,6 +554,26 @@ tracker_db_journal_init (const gchar *filename,
}
static gboolean
+db_journal_ontology_init (void)
+{
+ gboolean ret;
+ gchar *filename;
+
+ g_return_val_if_fail (ontology_writer.journal == 0, FALSE);
+
+ filename = g_build_filename (g_get_user_data_dir (),
+ "tracker",
+ "data",
+ TRACKER_DB_JOURNAL_ONTOLOGY_FILENAME,
+ NULL);
+
+ ret = db_journal_writer_init (&ontology_writer, FALSE, FALSE, filename);
+ g_free (filename);
+
+ return ret;
+}
+
+static gboolean
db_journal_writer_shutdown (JournalWriter *jwriter)
{
g_free (jwriter->journal_filename);
@@ -600,6 +624,9 @@ db_journal_writer_start_transaction (JournalWriter *jwriter,
guint size;
g_return_val_if_fail (jwriter->journal > 0, FALSE);
+ g_return_val_if_fail (current_transaction_format == TRANSACTION_FORMAT_NONE, FALSE);
+
+ current_transaction_format = kind;
size = sizeof (guint32) * 3;
cur_block_maybe_expand (jwriter, size);
@@ -636,7 +663,11 @@ tracker_db_journal_start_transaction (time_t time)
gboolean
tracker_db_journal_start_ontology_transaction (time_t time)
{
- return db_journal_writer_start_transaction (&writer, time,
+ if (!db_journal_ontology_init ()) {
+ return FALSE;
+ }
+
+ return db_journal_writer_start_transaction (&ontology_writer, time,
TRANSACTION_FORMAT_ONTOLOGY);
}
@@ -882,9 +913,17 @@ gboolean
tracker_db_journal_rollback_transaction (void)
{
g_return_val_if_fail (writer.journal > 0, FALSE);
+ g_return_val_if_fail (current_transaction_format != TRANSACTION_FORMAT_NONE, FALSE);
cur_block_kill (&writer);
+ if (current_transaction_format == TRANSACTION_FORMAT_ONTOLOGY) {
+ cur_block_kill (&ontology_writer);
+ db_journal_writer_shutdown (&ontology_writer);
+ }
+
+ current_transaction_format = TRANSACTION_FORMAT_NONE;
+
return TRUE;
}
@@ -949,8 +988,17 @@ tracker_db_journal_commit_db_transaction (void)
{
gboolean ret;
+ g_return_val_if_fail (current_transaction_format != TRANSACTION_FORMAT_NONE, FALSE);
+
ret = db_journal_writer_commit_db_transaction (&writer);
+ if (current_transaction_format == TRANSACTION_FORMAT_ONTOLOGY) {
+ db_journal_writer_commit_db_transaction (&ontology_writer);
+ db_journal_writer_shutdown (&ontology_writer);
+ }
+
+ current_transaction_format = TRANSACTION_FORMAT_NONE;
+
#if GLIB_CHECK_VERSION (2, 24, 2)
if (ret) {
if (rotating_settings.do_rotating && (writer.cur_size > rotating_settings.chunk_size)) {
diff --git a/src/libtracker-data/tracker-db-journal.h b/src/libtracker-data/tracker-db-journal.h
index 6783aff..71ec08b 100644
--- a/src/libtracker-data/tracker-db-journal.h
+++ b/src/libtracker-data/tracker-db-journal.h
@@ -27,9 +27,10 @@
G_BEGIN_DECLS
-#define TRACKER_DB_JOURNAL_ERROR_DOMAIN "TrackerDBJournal"
-#define TRACKER_DB_JOURNAL_ERROR tracker_db_journal_error_quark()
-#define TRACKER_DB_JOURNAL_FILENAME "tracker-store.journal"
+#define TRACKER_DB_JOURNAL_ERROR_DOMAIN "TrackerDBJournal"
+#define TRACKER_DB_JOURNAL_ERROR tracker_db_journal_error_quark()
+#define TRACKER_DB_JOURNAL_FILENAME "tracker-store.journal"
+#define TRACKER_DB_JOURNAL_ONTOLOGY_FILENAME "tracker-store.ontology.journal"
typedef enum {
TRACKER_DB_JOURNAL_START,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]