[tracker/gdbus-porting] Move the code in handle_method_call into separate functions



commit 62f32ffa8e8620956068f3435ea3803a294103a4
Author: Philip Van Hoof <philip codeminded be>
Date:   Thu Dec 30 11:44:12 2010 +0100

    Move the code in handle_method_call into separate functions

 src/libtracker-miner/tracker-miner-object.c |  296 ++++++++++++++++-----------
 1 files changed, 181 insertions(+), 115 deletions(-)
---
diff --git a/src/libtracker-miner/tracker-miner-object.c b/src/libtracker-miner/tracker-miner-object.c
index 21b6aa7..8c603cc 100644
--- a/src/libtracker-miner/tracker-miner-object.c
+++ b/src/libtracker-miner/tracker-miner-object.c
@@ -657,153 +657,217 @@ miner_finalize (GObject *object)
 
 
 static void
-handle_method_call (GDBusConnection       *connection,
-                    const gchar           *sender,
-                    const gchar           *object_path,
-                    const gchar           *interface_name,
-                    const gchar           *method_name,
-                    GVariant              *parameters,
-                    GDBusMethodInvocation *invocation,
-                    gpointer               user_data)
+handle_method_call_ignore_next_update (TrackerMiner          *miner,
+                                       GDBusMethodInvocation *invocation,
+                                       GVariant              *parameters)
 {
-	TrackerMiner *miner = user_data;
+	GStrv urls;
 	guint request_id;
 
-	tracker_gdbus_async_return_if_fail (miner != NULL, invocation);
+	request_id = tracker_dbus_get_next_request_id ();
+
+	g_variant_get (parameters, "as", &urls);
+
+	tracker_gdbus_request_new (request_id,
+	                           invocation,
+	                           "%s", __PRETTY_FUNCTION__);
+
+	tracker_miner_ignore_next_update (miner, urls);
+
+	tracker_gdbus_request_success (request_id, invocation);
+	g_dbus_method_invocation_return_value (invocation, NULL);
+}
+
+static void
+handle_method_call_resume (TrackerMiner          *miner,
+                           GDBusMethodInvocation *invocation,
+                           GVariant              *parameters)
+{
+	GError *local_error = NULL;
+	gint cookie;
+	guint request_id;
 
 	request_id = tracker_dbus_get_next_request_id ();
 
-	if (g_strcmp0 (method_name, "IgnoreNextUpdate") == 0) {
-		GStrv urls;
+	g_variant_get (parameters, "i", &cookie);
 
-		g_variant_get (parameters, "as", &urls);
+	tracker_gdbus_request_new (request_id,
+	                           invocation,
+	                           "%s(cookie:%d)",
+	                           __PRETTY_FUNCTION__,
+	                           cookie);
 
-		tracker_gdbus_request_new (request_id,
-		                           invocation,
-		                           "%s", __PRETTY_FUNCTION__);
+	if (!tracker_miner_resume (miner, cookie, &local_error)) {
+		GError *actual_error = NULL;
 
-		tracker_miner_ignore_next_update (miner, urls);
+		tracker_gdbus_request_failed (request_id,
+		                              invocation,
+		                              &actual_error,
+		                              local_error ? local_error->message : NULL);
 
-		tracker_gdbus_request_success (request_id, invocation);
-		g_dbus_method_invocation_return_value (invocation, NULL);
-	} else
-	if (g_strcmp0 (method_name, "Resume") == 0) {
-		GError *local_error = NULL;
-		gint cookie;
+		g_dbus_method_invocation_return_gerror (invocation, actual_error);
 
-		g_variant_get (parameters, "i", &cookie);
+		g_error_free (actual_error);
+		g_error_free (local_error);
+		return;
+	}
+
+	tracker_gdbus_request_success (request_id, invocation);
+	g_dbus_method_invocation_return_value (invocation, NULL);
+}
+
+static void
+handle_method_call_pause (TrackerMiner          *miner,
+                          GDBusMethodInvocation *invocation,
+                          GVariant              *parameters)
+{
+	GError *local_error = NULL;
+	gint cookie;
+	gchar *application = NULL, *reason = NULL;
+	guint request_id;
 
-		tracker_gdbus_request_new (request_id,
-		                           invocation,
-		                           "%s(cookie:%d)",
-		                           __PRETTY_FUNCTION__,
-		                           cookie);
+	request_id = tracker_dbus_get_next_request_id ();
 
-		if (!tracker_miner_resume (miner, cookie, &local_error)) {
-			GError *actual_error = NULL;
+	g_variant_get (parameters, "ss", &application, &reason);
 
-			tracker_gdbus_request_failed (request_id,
-			                              invocation,
-			                              &actual_error,
-			                              local_error ? local_error->message : NULL);
+	tracker_gdbus_async_return_if_fail (application != NULL, invocation);
+	tracker_gdbus_async_return_if_fail (reason != NULL, invocation);
 
-			g_dbus_method_invocation_return_gerror (invocation, actual_error);
+	tracker_gdbus_request_new (request_id, invocation,
+	                           "%s(application:'%s', reason:'%s')",
+	                           __PRETTY_FUNCTION__,
+	                           application,
+	                           reason);
 
-			g_error_free (actual_error);
-			g_error_free (local_error);
-			return;
-		}
+	cookie = tracker_miner_pause_internal (miner, application, reason, &local_error);
+	if (cookie == -1) {
+		GError *actual_error = NULL;
 
-		tracker_gdbus_request_success (request_id, invocation);
-		g_dbus_method_invocation_return_value (invocation, NULL);
-	} else
-	if (g_strcmp0 (method_name, "Pause") == 0) {
-		GError *local_error = NULL;
-		gint cookie;
-		gchar *application = NULL, *reason = NULL;
+		tracker_gdbus_request_failed (request_id,
+		                              invocation,
+		                              &actual_error,
+		                              local_error ? local_error->message : NULL);
 
-		g_variant_get (parameters, "ss", &application, &reason);
+		g_dbus_method_invocation_return_gerror (invocation, actual_error);
 
-		tracker_gdbus_async_return_if_fail (application != NULL, invocation);
-		tracker_gdbus_async_return_if_fail (reason != NULL, invocation);
+		g_error_free (actual_error);
+		g_error_free (local_error);
 
-		tracker_gdbus_request_new (request_id, invocation,
-		                           "%s(application:'%s', reason:'%s')",
-		                           __PRETTY_FUNCTION__,
-		                           application,
-		                           reason);
+		return;
+	}
 
-		cookie = tracker_miner_pause_internal (miner, application, reason, &local_error);
-		if (cookie == -1) {
-			GError *actual_error = NULL;
+	tracker_gdbus_request_success (request_id, invocation);
+	g_dbus_method_invocation_return_value (invocation,
+	                                       g_variant_new ("i", cookie));
+}
 
-			tracker_gdbus_request_failed (request_id,
-			                              invocation,
-			                              &actual_error,
-			                              local_error ? local_error->message : NULL);
+static void
+handle_method_call_get_pause_details (TrackerMiner          *miner,
+                                      GDBusMethodInvocation *invocation,
+                                      GVariant              *parameters)
+{
+	GSList *applications, *reasons;
+	GStrv applications_strv, reasons_strv;
+	GHashTableIter iter;
+	gpointer key, value;
+	guint request_id;
 
-			g_dbus_method_invocation_return_gerror (invocation, actual_error);
+	request_id = tracker_dbus_get_next_request_id ();
 
-			g_error_free (actual_error);
-			g_error_free (local_error);
+	tracker_gdbus_request_new (request_id, invocation, "%s()", __PRETTY_FUNCTION__);
 
-			return;
-		}
+	applications = NULL;
+	reasons = NULL;
+	g_hash_table_iter_init (&iter, miner->private->pauses);
+	while (g_hash_table_iter_next (&iter, &key, &value)) {
+		PauseData *pd = value;
+
+		applications = g_slist_prepend (applications, pd->application);
+		reasons = g_slist_prepend (reasons, pd->reason);
+	}
+	applications = g_slist_reverse (applications);
+	reasons = g_slist_reverse (reasons);
+	applications_strv = tracker_gslist_to_string_list (applications);
+	reasons_strv = tracker_gslist_to_string_list (reasons);
+
+	tracker_gdbus_request_success (request_id, invocation);
+	g_dbus_method_invocation_return_value (invocation,
+	                                       g_variant_new ("asas",
+	                                                      applications_strv,
+	                                                      reasons_strv));
+
+	g_strfreev (applications_strv);
+	g_strfreev (reasons_strv);
+	g_slist_free (applications);
+	g_slist_free (reasons);
+}
+
+static void
+handle_method_call_get_progress (TrackerMiner          *miner,
+                                 GDBusMethodInvocation *invocation,
+                                 GVariant              *parameters)
+{
+	guint request_id;
+
+	request_id = tracker_dbus_get_next_request_id ();
+
+	tracker_gdbus_request_new (request_id, invocation, "%s()", __PRETTY_FUNCTION__);
+
+	tracker_gdbus_request_success (request_id, invocation);
+	g_dbus_method_invocation_return_value (invocation,
+	                                       g_variant_new ("i", miner->private->progress));
+}
 
-		tracker_gdbus_request_success (request_id, invocation);
-		g_dbus_method_invocation_return_value (invocation,
-		                                       g_variant_new ("i", cookie));
+static void
+handle_method_call_get_status (TrackerMiner          *miner,
+                               GDBusMethodInvocation *invocation,
+                               GVariant              *parameters)
+{
+	guint request_id;
+
+	request_id = tracker_dbus_get_next_request_id ();
+
+	tracker_gdbus_request_new (request_id, invocation, "%s()", __PRETTY_FUNCTION__);
+
+	tracker_gdbus_request_success (request_id, invocation);
+	g_dbus_method_invocation_return_value (invocation,
+	                                       g_variant_new ("s", miner->private->status));
+
+}
+
+static void
+handle_method_call (GDBusConnection       *connection,
+                    const gchar           *sender,
+                    const gchar           *object_path,
+                    const gchar           *interface_name,
+                    const gchar           *method_name,
+                    GVariant              *parameters,
+                    GDBusMethodInvocation *invocation,
+                    gpointer               user_data)
+{
+	TrackerMiner *miner = user_data;
+
+	tracker_gdbus_async_return_if_fail (miner != NULL, invocation);
+
+	if (g_strcmp0 (method_name, "IgnoreNextUpdate") == 0) {
+		handle_method_call_ignore_next_update (miner, invocation, parameters);
+	} else
+	if (g_strcmp0 (method_name, "Resume") == 0) {
+		handle_method_call_resume (miner, invocation, parameters);
+	} else
+	if (g_strcmp0 (method_name, "Pause") == 0) {
+		handle_method_call_pause (miner, invocation, parameters);
 	} else
 	if (g_strcmp0 (method_name, "GetPauseDetails") == 0) {
-		GSList *applications, *reasons;
-		GStrv applications_strv, reasons_strv;
-		GHashTableIter iter;
-		gpointer key, value;
-		guint request_id;
-
-		tracker_gdbus_request_new (request_id, invocation, "%s()", __PRETTY_FUNCTION__);
-
-		applications = NULL;
-		reasons = NULL;
-		g_hash_table_iter_init (&iter, miner->private->pauses);
-		while (g_hash_table_iter_next (&iter, &key, &value)) {
-			PauseData *pd = value;
-
-			applications = g_slist_prepend (applications, pd->application);
-			reasons = g_slist_prepend (reasons, pd->reason);
-		}
-		applications = g_slist_reverse (applications);
-		reasons = g_slist_reverse (reasons);
-		applications_strv = tracker_gslist_to_string_list (applications);
-		reasons_strv = tracker_gslist_to_string_list (reasons);
-
-		tracker_gdbus_request_success (request_id, invocation);
-		g_dbus_method_invocation_return_value (invocation,
-		                                       g_variant_new ("asas",
-		                                                      applications_strv,
-		                                                      reasons_strv));
-
-		g_strfreev (applications_strv);
-		g_strfreev (reasons_strv);
-		g_slist_free (applications);
-		g_slist_free (reasons);
+		handle_method_call_get_pause_details (miner, invocation, parameters);
 	} else
 	if (g_strcmp0 (method_name, "GetProgress") == 0) {
-
-		tracker_gdbus_request_new (request_id, invocation, "%s()", __PRETTY_FUNCTION__);
-
-		tracker_gdbus_request_success (request_id, invocation);
-		g_dbus_method_invocation_return_value (invocation,
-		                                       g_variant_new ("i", miner->private->progress));
+		handle_method_call_get_progress (miner, invocation, parameters);
 	} else
 	if (g_strcmp0 (method_name, "GetStatus") == 0) {
-
-
-		tracker_gdbus_request_new (request_id, invocation, "%s()", __PRETTY_FUNCTION__);
-
-		tracker_gdbus_request_success (request_id, invocation);
-		g_dbus_method_invocation_return_value (invocation,
-		                                       g_variant_new ("s", miner->private->status));
+		handle_method_call_get_status (miner, invocation, parameters);
+	} else {
+		g_assert_not_reached ();
 	}
 }
 
@@ -816,6 +880,7 @@ handle_get_property (GDBusConnection  *connection,
                      GError          **error,
                      gpointer          user_data)
 {
+	g_assert_not_reached ();
 	return NULL;
 }
 
@@ -829,6 +894,7 @@ handle_set_property (GDBusConnection  *connection,
                      GError          **error,
                      gpointer          user_data)
 {
+	g_assert_not_reached ();
 	return TRUE;
 }
 



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