[tracker/wal: 3/18] tracker-store: Drop special batch handling
- From: Jürg Billeter <juergbi src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/wal: 3/18] tracker-store: Drop special batch handling
- Date: Fri, 13 Aug 2010 15:15:55 +0000 (UTC)
commit dc9c15252e81044f5cb03cbc56747e86b220d4d7
Author: Jürg Billeter <j bitron ch>
Date: Tue Jun 29 15:03:24 2010 +0200
tracker-store: Drop special batch handling
The only difference between batch and regular updates is that batch
requests are handled at lower priority.
src/plugins/kmail/tracker-kmail-registrar.c | 6 +-
src/tracker-store/tracker-resources.c | 40 +---------
src/tracker-store/tracker-steroids.c | 1 -
src/tracker-store/tracker-store.c | 111 +--------------------------
src/tracker-store/tracker-store.h | 6 --
5 files changed, 10 insertions(+), 154 deletions(-)
---
diff --git a/src/plugins/kmail/tracker-kmail-registrar.c b/src/plugins/kmail/tracker-kmail-registrar.c
index 7bff9e7..712aac2 100644
--- a/src/plugins/kmail/tracker-kmail-registrar.c
+++ b/src/plugins/kmail/tracker-kmail-registrar.c
@@ -358,7 +358,7 @@ perform_set (TrackerKMailRegistrar *object,
tracker_store_sparql_update (tracker_sparql_builder_get_result (sparql),
TRACKER_STORE_PRIORITY_LOW,
- TRUE, NULL, "KMail plugin", NULL, NULL);
+ NULL, "KMail plugin", NULL, NULL);
g_object_unref (sparql);
}
@@ -370,7 +370,7 @@ perform_unset (TrackerKMailRegistrar *object,
gchar *sparql = g_strdup_printf ("DELETE FROM <%s> { <%s> a rdfs:Resource }",
subject, subject);
- tracker_store_sparql_update (sparql, TRACKER_STORE_PRIORITY_LOW, TRUE, NULL,
+ tracker_store_sparql_update (sparql, TRACKER_STORE_PRIORITY_LOW, NULL,
"KMail plugin", NULL, NULL);
g_free (sparql);
@@ -380,7 +380,7 @@ static void
perform_cleanup (TrackerKMailRegistrar *object)
{
tracker_store_sparql_update ("DELETE FROM <"DATASOURCE_URN"> { ?s a rdfs:Resource } WHERE { ?s nie:dataSource <" DATASOURCE_URN "> }",
- TRACKER_STORE_PRIORITY_LOW, TRUE, NULL, "KMail plugin", NULL, NULL);
+ TRACKER_STORE_PRIORITY_LOW, NULL, "KMail plugin", NULL, NULL);
/* tracker_store_queue_sparql_update ("DELETE FROM <"DATASOURCE_URN"> { ?s ?p ?o } WHERE { ?s nie:dataSource <" DATASOURCE_URN "> }", NULL, NULL, NULL, NULL); */
}
diff --git a/src/tracker-store/tracker-resources.c b/src/tracker-store/tracker-resources.c
index 3d33bb0..ef733ec 100644
--- a/src/tracker-store/tracker-resources.c
+++ b/src/tracker-store/tracker-resources.c
@@ -396,7 +396,7 @@ tracker_resources_sparql_update (TrackerResources *self,
sender = dbus_g_method_get_sender (context);
- tracker_store_sparql_update (update, TRACKER_STORE_PRIORITY_HIGH, FALSE,
+ tracker_store_sparql_update (update, TRACKER_STORE_PRIORITY_HIGH,
update_callback, sender,
info, destroy_method_info);
@@ -503,53 +503,19 @@ tracker_resources_batch_sparql_update (TrackerResources *self,
sender = dbus_g_method_get_sender (context);
- tracker_store_sparql_update (update, TRACKER_STORE_PRIORITY_LOW, TRUE,
+ tracker_store_sparql_update (update, TRACKER_STORE_PRIORITY_LOW,
update_callback, sender,
info, destroy_method_info);
g_free (sender);
}
-static void
-batch_commit_callback (gpointer user_data)
-{
- TrackerDBusMethodInfo *info = user_data;
-
- tracker_data_sync ();
-
- tracker_dbus_request_success (info->request_id,
- info->context);
-
- dbus_g_method_return (info->context);
-}
-
void
tracker_resources_batch_commit (TrackerResources *self,
DBusGMethodInvocation *context,
GError **error)
{
- TrackerDBusMethodInfo *info;
- guint request_id;
- gchar *sender;
-
- request_id = tracker_dbus_get_next_request_id ();
-
- tracker_dbus_request_new (request_id,
- context,
- "%s()",
- __FUNCTION__);
-
- info = g_slice_new (TrackerDBusMethodInfo);
-
- info->request_id = request_id;
- info->context = context;
-
- sender = dbus_g_method_get_sender (context);
-
- tracker_store_queue_commit (batch_commit_callback, sender, info,
- destroy_method_info);
-
- g_free (sender);
+ /* no longer needed */
}
diff --git a/src/tracker-store/tracker-steroids.c b/src/tracker-store/tracker-steroids.c
index 7f6e99a..414c2c6 100644
--- a/src/tracker-store/tracker-steroids.c
+++ b/src/tracker-store/tracker-steroids.c
@@ -617,7 +617,6 @@ steroids_update (TrackerSteroids *steroids,
} else {
tracker_store_sparql_update (query,
batch ? TRACKER_STORE_PRIORITY_LOW : TRACKER_STORE_PRIORITY_HIGH,
- batch,
update_callback,
sender,
info,
diff --git a/src/tracker-store/tracker-store.c b/src/tracker-store/tracker-store.c
index 2d16896..a68631d 100644
--- a/src/tracker-store/tracker-store.c
+++ b/src/tracker-store/tracker-store.c
@@ -39,7 +39,6 @@
#include "tracker-store.h"
-#define TRACKER_STORE_TRANSACTION_MAX 4000
#define TRACKER_STORE_MAX_CONCURRENT_QUERIES 2
#define TRACKER_STORE_N_TURTLE_STATEMENTS 50
@@ -49,8 +48,7 @@
typedef struct {
gboolean have_handler, have_sync_handler;
- gboolean batch_mode, start_log;
- guint batch_count;
+ gboolean start_log;
GQueue *queues[TRACKER_STORE_N_PRIORITIES];
guint handler, sync_handler;
guint n_queries_running;
@@ -67,7 +65,6 @@ typedef enum {
TRACKER_STORE_TASK_TYPE_QUERY,
TRACKER_STORE_TASK_TYPE_UPDATE,
TRACKER_STORE_TASK_TYPE_UPDATE_BLANK,
- TRACKER_STORE_TASK_TYPE_COMMIT,
TRACKER_STORE_TASK_TYPE_TURTLE,
} TrackerStoreTaskType;
@@ -82,7 +79,6 @@ typedef struct {
} query;
struct {
gchar *query;
- gboolean batch;
GPtrArray *blank_nodes;
} update;
struct {
@@ -102,7 +98,6 @@ typedef struct {
} query;
TrackerStoreSparqlUpdateCallback update_callback;
TrackerStoreSparqlUpdateBlankCallback update_blank_callback;
- TrackerStoreCommitCallback commit_callback;
TrackerStoreTurtleCallback turtle_callback;
} callback;
} TrackerStoreTask;
@@ -219,27 +214,6 @@ process_turtle_file_part (TrackerTurtleReader *reader, GError **error)
return FALSE;
}
-static void
-begin_batch (TrackerStorePrivate *private)
-{
- if (!private->batch_mode) {
- private->batch_mode = TRUE;
- private->batch_count = 0;
- }
-}
-
-static void
-end_batch (TrackerStorePrivate *private)
-{
- if (private->batch_mode) {
- /* commit pending batch items */
- tracker_data_notify_transaction ();
-
- private->batch_mode = FALSE;
- private->batch_count = 0;
- }
-}
-
static gboolean
task_ready (TrackerStorePrivate *private)
{
@@ -371,7 +345,7 @@ task_finish_cb (gpointer data)
check_running_tasks_watchdog (private);
private->n_queries_running--;
} else if (task->type == TRACKER_STORE_TASK_TYPE_UPDATE) {
- if (!task->data.update.batch && !task->error) {
+ if (!task->error) {
tracker_data_notify_transaction ();
}
@@ -385,7 +359,7 @@ task_finish_cb (gpointer data)
private->update_running = FALSE;
} else if (task->type == TRACKER_STORE_TASK_TYPE_UPDATE_BLANK) {
- if (!task->data.update.batch && !task->error) {
+ if (!task->error) {
tracker_data_notify_transaction ();
}
@@ -432,14 +406,6 @@ task_finish_cb (gpointer data)
/* Remove the task now that we're done with it */
g_queue_pop_head (private->queues[TRACKER_STORE_PRIORITY_TURTLE]);
}
- } else if (task->type == TRACKER_STORE_TASK_TYPE_COMMIT) {
- tracker_data_notify_transaction ();
-
- if (task->callback.commit_callback) {
- task->callback.commit_callback (task->user_data);
- }
-
- private->update_running = FALSE;
}
if (task->destroy) {
@@ -487,39 +453,9 @@ pool_dispatch_cb (gpointer data,
g_object_unref (cursor);
} else if (task->type == TRACKER_STORE_TASK_TYPE_UPDATE) {
- if (task->data.update.batch) {
- begin_batch (private);
- } else {
- end_batch (private);
- }
-
tracker_data_update_sparql (task->data.update.query, &task->error);
-
- if (task->data.update.batch) {
- if (!task->error) {
- private->batch_count++;
- if (private->batch_count >= TRACKER_STORE_TRANSACTION_MAX) {
- end_batch (private);
- }
- }
- }
} else if (task->type == TRACKER_STORE_TASK_TYPE_UPDATE_BLANK) {
- if (task->data.update.batch) {
- begin_batch (private);
- } else {
- end_batch (private);
- }
-
task->data.update.blank_nodes = tracker_data_update_sparql_blank (task->data.update.query, &task->error);
-
- if (task->data.update.batch) {
- if (!task->error) {
- private->batch_count++;
- if (private->batch_count >= TRACKER_STORE_TRANSACTION_MAX) {
- end_batch (private);
- }
- }
- }
} else if (task->type == TRACKER_STORE_TASK_TYPE_TURTLE) {
if (!task->data.turtle.in_progress) {
task->data.turtle.reader = tracker_turtle_reader_new (task->data.turtle.path, &task->error);
@@ -532,21 +468,12 @@ pool_dispatch_cb (gpointer data,
task->data.turtle.in_progress = TRUE;
}
- begin_batch (private);
-
if (process_turtle_file_part (task->data.turtle.reader, &task->error)) {
/* import still in progress */
- private->batch_count++;
- if (private->batch_count >= TRACKER_STORE_TRANSACTION_MAX) {
- end_batch (private);
- }
} else {
/* import finished */
task->data.turtle.in_progress = FALSE;
- end_batch (private);
}
- } else if (task->type == TRACKER_STORE_TASK_TYPE_COMMIT) {
- end_batch (private);
}
g_idle_add (task_finish_cb, task);
@@ -591,8 +518,7 @@ queue_idle_handler (gpointer user_data)
task_run_async (private, task);
} else if (task->type == TRACKER_STORE_TASK_TYPE_UPDATE ||
- task->type == TRACKER_STORE_TASK_TYPE_UPDATE_BLANK ||
- task->type == TRACKER_STORE_TASK_TYPE_COMMIT) {
+ task->type == TRACKER_STORE_TASK_TYPE_UPDATE_BLANK) {
g_queue_pop_head (queue);
private->update_running = TRUE;
@@ -702,31 +628,6 @@ start_handler (TrackerStorePrivate *private)
}
void
-tracker_store_queue_commit (TrackerStoreCommitCallback callback,
- const gchar *client_id,
- gpointer user_data,
- GDestroyNotify destroy)
-{
- TrackerStorePrivate *private;
- TrackerStoreTask *task;
-
- private = g_static_private_get (&private_key);
- g_return_if_fail (private != NULL);
-
- task = g_slice_new0 (TrackerStoreTask);
- task->type = TRACKER_STORE_TASK_TYPE_COMMIT;
- task->user_data = user_data;
- task->callback.commit_callback = callback;
- task->destroy = destroy;
- task->client_id = g_strdup (client_id);
- task->data.update.query = NULL;
-
- g_queue_push_tail (private->queues[TRACKER_STORE_PRIORITY_LOW], task);
-
- check_handler (private);
-}
-
-void
tracker_store_sparql_query (const gchar *sparql,
TrackerStorePriority priority,
TrackerStoreSparqlQueryInThread in_thread,
@@ -761,7 +662,6 @@ tracker_store_sparql_query (const gchar *sparql,
void
tracker_store_sparql_update (const gchar *sparql,
TrackerStorePriority priority,
- gboolean batch,
TrackerStoreSparqlUpdateCallback callback,
const gchar *client_id,
gpointer user_data,
@@ -778,7 +678,6 @@ tracker_store_sparql_update (const gchar *sparql,
task = g_slice_new0 (TrackerStoreTask);
task->type = TRACKER_STORE_TASK_TYPE_UPDATE;
task->data.update.query = g_strdup (sparql);
- task->data.update.batch = batch;
task->user_data = user_data;
task->callback.update_callback = callback;
task->destroy = destroy;
@@ -909,8 +808,6 @@ tracker_store_unreg_batches (const gchar *client_id)
task->callback.update_callback (error, task->user_data);
} else if (task->type == TRACKER_STORE_TASK_TYPE_UPDATE_BLANK) {
task->callback.update_blank_callback (NULL, error, task->user_data);
- } else if (task->type == TRACKER_STORE_TASK_TYPE_COMMIT) {
- task->callback.commit_callback (task->user_data);
}
task->destroy (task->user_data);
diff --git a/src/tracker-store/tracker-store.h b/src/tracker-store/tracker-store.h
index 6df432b..8071ff5 100644
--- a/src/tracker-store/tracker-store.h
+++ b/src/tracker-store/tracker-store.h
@@ -49,16 +49,11 @@ typedef void (* TrackerStoreSparqlUpdateCallback) (GError *error,
typedef void (* TrackerStoreSparqlUpdateBlankCallback) (GPtrArray *blank_nodes,
GError *error,
gpointer user_data);
-typedef void (* TrackerStoreCommitCallback) (gpointer user_data);
typedef void (* TrackerStoreTurtleCallback) (GError *error,
gpointer user_data);
void tracker_store_init (void);
void tracker_store_shutdown (void);
-void tracker_store_queue_commit (TrackerStoreCommitCallback callback,
- const gchar *client_id,
- gpointer user_data,
- GDestroyNotify destroy);
void tracker_store_sparql_query (const gchar *sparql,
TrackerStorePriority priority,
TrackerStoreSparqlQueryInThread in_thread,
@@ -68,7 +63,6 @@ void tracker_store_sparql_query (const gchar *sparql,
GDestroyNotify destroy);
void tracker_store_sparql_update (const gchar *sparql,
TrackerStorePriority priority,
- gboolean batch,
TrackerStoreSparqlUpdateCallback callback,
const gchar *client_id,
gpointer user_data,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]