aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBen Chan <benchan@chromium.org>2017-07-11 16:05:55 -0700
committerAleksander Morgado <aleksander@aleksander.es>2017-10-20 17:20:24 +0200
commit0b942a6759a7ebfa2afe468ecfb02baeb653b8b5 (patch)
tree9fa353b63dda30d30d3148a3b03746b45d068a98
parentbba2386238d3f672946a20ea69d00fb1f95cb7d9 (diff)
broadband-modem-qmi: port modem_load_supported_ip_modes to use GTask
-rw-r--r--src/mm-broadband-modem-qmi.c25
1 files changed, 10 insertions, 15 deletions
diff --git a/src/mm-broadband-modem-qmi.c b/src/mm-broadband-modem-qmi.c
index b220d9d9..e41e684e 100644
--- a/src/mm-broadband-modem-qmi.c
+++ b/src/mm-broadband-modem-qmi.c
@@ -2503,7 +2503,7 @@ modem_load_supported_modes_finish (MMIfaceModem *self,
GAsyncResult *res,
GError **error)
{
- return g_array_ref (g_simple_async_result_get_op_res_gpointer (G_SIMPLE_ASYNC_RESULT (res)));
+ return g_task_propagate_pointer (G_TASK (res), error);
}
static void
@@ -2512,22 +2512,18 @@ modem_load_supported_modes (MMIfaceModem *_self,
gpointer user_data)
{
MMBroadbandModemQmi *self = MM_BROADBAND_MODEM_QMI (_self);
- GSimpleAsyncResult *result;
+ GTask *task;
GArray *combinations;
MMModemModeCombination mode;
- result = g_simple_async_result_new (G_OBJECT (self),
- callback,
- user_data,
- modem_load_supported_modes);
+ task = g_task_new (self, NULL, callback, user_data);
if (!self->priv->supported_radio_interfaces) {
- g_simple_async_result_set_error (result,
- MM_CORE_ERROR,
- MM_CORE_ERROR_FAILED,
- "Cannot load supported modes, no radio interface list");
- g_simple_async_result_complete_in_idle (result);
- g_object_unref (result);
+ g_task_return_new_error (task,
+ MM_CORE_ERROR,
+ MM_CORE_ERROR_FAILED,
+ "Cannot load supported modes, no radio interface list");
+ g_object_unref (task);
return;
}
@@ -2628,9 +2624,8 @@ modem_load_supported_modes (MMIfaceModem *_self,
combinations = filtered;
}
- g_simple_async_result_set_op_res_gpointer (result, combinations, (GDestroyNotify) g_array_unref);
- g_simple_async_result_complete_in_idle (result);
- g_object_unref (result);
+ g_task_return_pointer (task, combinations, (GDestroyNotify) g_array_unref);
+ g_object_unref (task);
}
/*****************************************************************************/