aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorBen Chan <benchan@chromium.org>2017-07-11 14:27:02 -0700
committerAleksander Morgado <aleksander@aleksander.es>2017-10-20 17:20:24 +0200
commite365cf531ccbdd4101ae5507ba439fe27875f758 (patch)
treed1ba3e913e7700496e7341c4e7164fe6174597a0 /src
parent942a3565e25aa17317c528fb8a7a1832d97aa784 (diff)
broadband-modem-qmi: port modem_3gpp_load_operator_name to use GTask
Diffstat (limited to 'src')
-rw-r--r--src/mm-broadband-modem-qmi.c38
1 files changed, 17 insertions, 21 deletions
diff --git a/src/mm-broadband-modem-qmi.c b/src/mm-broadband-modem-qmi.c
index c0a4197b..a34fdb50 100644
--- a/src/mm-broadband-modem-qmi.c
+++ b/src/mm-broadband-modem-qmi.c
@@ -4379,37 +4379,33 @@ modem_3gpp_scan_networks (MMIfaceModem3gpp *self,
/* Load operator name (3GPP interface) */
static gchar *
-modem_3gpp_load_operator_name_finish (MMIfaceModem3gpp *_self,
+modem_3gpp_load_operator_name_finish (MMIfaceModem3gpp *self,
GAsyncResult *res,
GError **error)
{
- MMBroadbandModemQmi *self = MM_BROADBAND_MODEM_QMI (_self);
-
- if (self->priv->current_operator_description)
- return g_strdup (self->priv->current_operator_description);
-
- g_set_error (error,
- MM_CORE_ERROR,
- MM_CORE_ERROR_FAILED,
- "Current operator description is still unknown");
- return NULL;
+ return g_task_propagate_pointer (G_TASK (res), error);
}
static void
-modem_3gpp_load_operator_name (MMIfaceModem3gpp *self,
+modem_3gpp_load_operator_name (MMIfaceModem3gpp *_self,
GAsyncReadyCallback callback,
gpointer user_data)
{
- GSimpleAsyncResult *result;
+ MMBroadbandModemQmi *self = MM_BROADBAND_MODEM_QMI (_self);
+ GTask *task;
- /* Just finish the async operation */
- result = g_simple_async_result_new (G_OBJECT (self),
- callback,
- user_data,
- modem_3gpp_load_operator_name);
- g_simple_async_result_set_op_res_gboolean (result, TRUE);
- g_simple_async_result_complete_in_idle (result);
- g_object_unref (result);
+ task = g_task_new (self, NULL, callback, user_data);
+
+ if (self->priv->current_operator_description)
+ g_task_return_pointer (task,
+ g_strdup (self->priv->current_operator_description),
+ g_free);
+ else
+ g_task_return_new_error (task,
+ MM_CORE_ERROR,
+ MM_CORE_ERROR_FAILED,
+ "Current operator description is still unknown");
+ g_object_unref (task);
}
/*****************************************************************************/