summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBen Chan <benchan@chromium.org>2017-07-11 14:38:44 -0700
committerAleksander Morgado <aleksander@aleksander.es>2017-10-20 17:20:24 +0200
commit2ba17be8b6a8472797b37abfbf05eecd0dd4a65a (patch)
tree598a7ab0955cdefc421d9175b3b3d8c02cf9ad1b
parent2aaac123ac971537b9a42e225eb9129e2ac05fec (diff)
downloadModemManager-2ba17be8b6a8472797b37abfbf05eecd0dd4a65a.tar.gz
broadband-modem-qmi: port modem_create_bearer to use GTask
-rw-r--r--src/mm-broadband-modem-qmi.c21
1 files changed, 6 insertions, 15 deletions
diff --git a/src/mm-broadband-modem-qmi.c b/src/mm-broadband-modem-qmi.c
index 54791c8a8..1eafa1ead 100644
--- a/src/mm-broadband-modem-qmi.c
+++ b/src/mm-broadband-modem-qmi.c
@@ -298,12 +298,7 @@ modem_create_bearer_finish (MMIfaceModem *self,
GAsyncResult *res,
GError **error)
{
- MMBaseBearer *bearer;
-
- bearer = g_simple_async_result_get_op_res_gpointer (G_SIMPLE_ASYNC_RESULT (res));
- mm_dbg ("New bearer created at DBus path '%s'", mm_base_bearer_get_path (bearer));
-
- return g_object_ref (bearer);
+ return g_task_propagate_pointer (G_TASK (res), error);
}
static void
@@ -313,18 +308,14 @@ modem_create_bearer (MMIfaceModem *self,
gpointer user_data)
{
MMBaseBearer *bearer;
- GSimpleAsyncResult *result;
- /* Set a new ref to the bearer object as result */
- result = g_simple_async_result_new (G_OBJECT (self),
- callback,
- user_data,
- modem_create_bearer);
+ GTask *task;
/* We just create a MMBearerQmi */
bearer = mm_bearer_qmi_new (MM_BROADBAND_MODEM_QMI (self), properties);
- g_simple_async_result_set_op_res_gpointer (result, bearer, g_object_unref);
- g_simple_async_result_complete_in_idle (result);
- g_object_unref (result);
+
+ task = g_task_new (self, NULL, callback, user_data);
+ g_task_return_pointer (task, bearer, g_object_unref);
+ g_object_unref (task);
}
/*****************************************************************************/