[gnome-online-miners/wip/rishi/insert-share: 9/24] miner: Get the cancellable from the GTask, not an instance variable



commit 0177a496ff43552ed626855541ab7690dadda1ab
Author: Debarshi Ray <debarshir gnome org>
Date:   Fri Sep 2 16:45:34 2016 +0200

    miner: Get the cancellable from the GTask, not an instance variable
    
    Just as each invocation of gom_miner_refresh_db_async should have a
    separate GTask, it should also use the GCancellable specifically passed
    by the caller. Having an instance variable in the GomMiner class
    violates this principle.
    
    There is also no need for a separate GCancellable in
    GomAccountMinerJob. We can use the one passed in by the caller.
    
    https://bugzilla.gnome.org/show_bug.cgi?id=770889

 src/gom-miner.c |   43 +++++++++++--------------------------------
 src/gom-miner.h |    1 -
 2 files changed, 11 insertions(+), 33 deletions(-)
---
diff --git a/src/gom-miner.c b/src/gom-miner.c
index db0b7f3..37f15c6 100644
--- a/src/gom-miner.c
+++ b/src/gom-miner.c
@@ -37,8 +37,6 @@ struct _GomMinerPrivate {
   TrackerSparqlConnection *connection;
   GError *connection_error;
 
-  GCancellable *cancellable;
-
   GList *pending_jobs;
 
   gchar *display_name;
@@ -52,10 +50,6 @@ static void cleanup_job (gpointer data, gpointer user_data);
 static void
 gom_account_miner_job_free (GomAccountMinerJob *job)
 {
-  if (job->miner_cancellable_id != 0)
-    g_cancellable_disconnect (job->miner->priv->cancellable,
-                              job->miner_cancellable_id);
-
   g_hash_table_unref (job->services);
   g_clear_object (&job->miner);
   g_clear_object (&job->account);
@@ -85,7 +79,6 @@ gom_miner_dispose (GObject *object)
 
   g_clear_object (&self->priv->client);
   g_clear_object (&self->priv->connection);
-  g_clear_object (&self->priv->cancellable);
 
   g_free (self->priv->display_name);
   g_strfreev (self->priv->index_types);
@@ -348,21 +341,12 @@ gom_account_miner_job_process_finish (GAsyncResult *res,
   return g_task_propagate_boolean (task, error);
 }
 
-static void
-miner_cancellable_cancelled_cb (GCancellable *cancellable,
-                                gpointer user_data)
-{
-  GomAccountMinerJob *job = user_data;
-
-  /* forward the cancel signal to the ongoing job */
-  g_cancellable_cancel (job->cancellable);
-}
-
 static GomAccountMinerJob *
 gom_account_miner_job_new (GomMiner *self,
                            GoaObject *object,
                            GTask *parent_task)
 {
+  GCancellable *cancellable;
   GomAccountMinerJob *retval;
   GoaAccount *account;
   GomMinerClass *miner_class = GOM_MINER_GET_CLASS (self);
@@ -370,22 +354,18 @@ gom_account_miner_job_new (GomMiner *self,
   account = goa_object_get_account (object);
   g_assert (account != NULL);
 
+  cancellable = g_task_get_cancellable (parent_task);
+
   retval = g_slice_new0 (GomAccountMinerJob);
   retval->miner = g_object_ref (self);
   retval->parent_task = g_object_ref (parent_task);
-  retval->cancellable = g_cancellable_new ();
+  retval->cancellable = g_object_ref (cancellable);
   retval->account = account;
   retval->connection = g_object_ref (self->priv->connection);
   retval->previous_resources =
     g_hash_table_new_full (g_str_hash, g_str_equal,
                            (GDestroyNotify) g_free, (GDestroyNotify) g_free);
 
-  if (self->priv->cancellable != NULL)
-      retval->miner_cancellable_id =
-        g_cancellable_connect (self->priv->cancellable,
-                               G_CALLBACK (miner_cancellable_cancelled_cb),
-                               retval, NULL);
-
   retval->services = miner_class->create_services (self, object);
   retval->datasource_urn = g_strdup_printf ("gd:goa-account:%s",
                                             goa_account_get_id (retval->account));
@@ -489,7 +469,7 @@ cleanup_old_accounts_done (gpointer data)
 }
 
 static void
-cleanup_job_do_cleanup (CleanupJob *job)
+cleanup_job_do_cleanup (CleanupJob *job, GCancellable *cancellable)
 {
   GomMiner *self = job->self;
   GList *l;
@@ -520,7 +500,7 @@ cleanup_job_do_cleanup (CleanupJob *job)
   tracker_sparql_connection_update (self->priv->connection,
                                     update->str,
                                     G_PRIORITY_DEFAULT,
-                                    self->priv->cancellable,
+                                    cancellable,
                                     &error);
   g_string_free (update, TRUE);
 
@@ -557,6 +537,7 @@ static void
 cleanup_job (gpointer data,
              gpointer user_data)
 {
+  GCancellable *cancellable;
   GSource *source;
   GString *select;
   GTask *task = G_TASK (data);
@@ -569,6 +550,7 @@ cleanup_job (gpointer data,
   GomMiner *self;
   GomMinerClass *klass;
 
+  cancellable = g_task_get_cancellable (task);
   job = (CleanupJob *) g_task_get_task_data (task);
   self = job->self;
   klass = GOM_MINER_GET_CLASS (self);
@@ -583,7 +565,7 @@ cleanup_job (gpointer data,
 
   cursor = tracker_sparql_connection_query (self->priv->connection,
                                             select->str,
-                                            self->priv->cancellable,
+                                            cancellable,
                                             &error);
   g_string_free (select, TRUE);
 
@@ -593,7 +575,7 @@ cleanup_job (gpointer data,
       goto out;
     }
 
-  while (tracker_sparql_cursor_next (cursor, self->priv->cancellable, NULL))
+  while (tracker_sparql_cursor_next (cursor, cancellable, NULL))
     {
       /* If the source we found is not in the current list, add
        * it to the cleanup list.
@@ -630,7 +612,7 @@ cleanup_job (gpointer data,
   g_object_unref (cursor);
 
   /* cleanup the DB */
-  cleanup_job_do_cleanup (job);
+  cleanup_job_do_cleanup (job, cancellable);
 
  out:
   source = g_idle_source_new ();
@@ -737,9 +719,6 @@ gom_miner_refresh_db_async (GomMiner *self,
       goto out;
     }
 
-  self->priv->cancellable =
-    (cancellable != NULL) ? g_object_ref (cancellable) : NULL;
-
   gom_miner_refresh_db_real (self, task);
 
  out:
diff --git a/src/gom-miner.h b/src/gom-miner.h
index 9f7aeb1..ed6e840 100644
--- a/src/gom-miner.h
+++ b/src/gom-miner.h
@@ -61,7 +61,6 @@ typedef struct _GomMinerPrivate GomMinerPrivate;
 typedef struct {
   GomMiner *miner;
   TrackerSparqlConnection *connection;
-  gulong miner_cancellable_id;
 
   GoaAccount *account;
   GHashTable *services;


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]