aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBen Chan <benchan@chromium.org>2017-07-11 14:28:37 -0700
committerAleksander Morgado <aleksander@aleksander.es>2017-10-20 17:20:24 +0200
commit607dee3a9553305432a3d513c8b777edee4d94dd (patch)
treebcca64a1b9cf91e27db34e8b34cca8fdc72fd612
parente365cf531ccbdd4101ae5507ba439fe27875f758 (diff)
broadband-modem-qmi: port modem_3gpp_load_operator_code to use GTask
-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 a34fdb50..a5e40bfe 100644
--- a/src/mm-broadband-modem-qmi.c
+++ b/src/mm-broadband-modem-qmi.c
@@ -4412,37 +4412,33 @@ modem_3gpp_load_operator_name (MMIfaceModem3gpp *_self,
/* Load operator code (3GPP interface) */
static gchar *
-modem_3gpp_load_operator_code_finish (MMIfaceModem3gpp *_self,
+modem_3gpp_load_operator_code_finish (MMIfaceModem3gpp *self,
GAsyncResult *res,
GError **error)
{
- MMBroadbandModemQmi *self = MM_BROADBAND_MODEM_QMI (_self);
-
- if (self->priv->current_operator_id)
- return g_strdup (self->priv->current_operator_id);
-
- g_set_error (error,
- MM_CORE_ERROR,
- MM_CORE_ERROR_FAILED,
- "Current operator MCC/MNC is still unknown");
- return NULL;
+ return g_task_propagate_pointer (G_TASK (res), error);
}
static void
-modem_3gpp_load_operator_code (MMIfaceModem3gpp *self,
+modem_3gpp_load_operator_code (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_code);
- 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_id)
+ g_task_return_pointer (task,
+ g_strdup (self->priv->current_operator_id),
+ g_free);
+ else
+ g_task_return_new_error (task,
+ MM_CORE_ERROR,
+ MM_CORE_ERROR_FAILED,
+ "Current operator MCC/MNC is still unknown");
+ g_object_unref (task);
}
/*****************************************************************************/