[tracker/direct-access: 3/85] tracker-store: Drop special batch handling
- From: Jürg Billeter <juergbi src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/direct-access: 3/85] tracker-store: Drop special batch handling
- Date: Tue, 20 Jul 2010 14:04:53 +0000 (UTC)
commit 35899a66d1ddefc0a6fc08aef51e4a36c2a1e707
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/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 --
4 files changed, 7 insertions(+), 151 deletions(-)
---
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 8fae74b..e435f16 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 87c0ded..5504008 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;
@@ -66,7 +64,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;
@@ -81,7 +78,6 @@ typedef struct {
} query;
struct {
gchar *query;
- gboolean batch;
GPtrArray *blank_nodes;
} update;
struct {
@@ -101,7 +97,6 @@ typedef struct {
} query;
TrackerStoreSparqlUpdateCallback update_callback;
TrackerStoreSparqlUpdateBlankCallback update_blank_callback;
- TrackerStoreCommitCallback commit_callback;
TrackerStoreTurtleCallback turtle_callback;
} callback;
} TrackerStoreTask;
@@ -218,27 +213,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)
{
@@ -369,7 +343,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 ();
}
@@ -383,7 +357,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 ();
}
@@ -430,14 +404,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) {
@@ -485,39 +451,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);
@@ -530,21 +466,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);
@@ -589,8 +516,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;
@@ -700,31 +626,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,
@@ -759,7 +660,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,
@@ -776,7 +676,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;
@@ -907,8 +806,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 7b1b5a9..3f86a15 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]