aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorBen Chan <benchan@chromium.org>2017-07-10 16:10:40 -0700
committerBen Chan <benchan@chromium.org>2017-07-11 10:30:39 -0700
commit9401aa70e52f14d3aba13798154f49b09c8ee38f (patch)
tree11527d56f3914e3c2e7b73c86739b78d985b1560 /src
parentfb38601ef4b388506008067f375a25330392c07d (diff)
broadband-modem-mbim: port modem_3gpp_load_operator_name to use GTask
Diffstat (limited to 'src')
-rw-r--r--src/mm-broadband-modem-mbim.c37
1 files changed, 16 insertions, 21 deletions
diff --git a/src/mm-broadband-modem-mbim.c b/src/mm-broadband-modem-mbim.c
index 19cac5e7..7f167233 100644
--- a/src/mm-broadband-modem-mbim.c
+++ b/src/mm-broadband-modem-mbim.c
@@ -2537,37 +2537,32 @@ modem_3gpp_enable_unsolicited_events (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)
{
- MMBroadbandModemMbim *self = MM_BROADBAND_MODEM_MBIM (_self);
-
- if (self->priv->current_operator_name)
- return g_strdup (self->priv->current_operator_name);
-
- g_set_error (error,
- MM_CORE_ERROR,
- MM_CORE_ERROR_FAILED,
- "Current operator name 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;
+ MMBroadbandModemMbim *self = MM_BROADBAND_MODEM_MBIM (_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_name)
+ g_task_return_pointer (task,
+ g_strdup (self->priv->current_operator_name),
+ g_free);
+ else
+ g_task_return_new_error (task,
+ MM_CORE_ERROR,
+ MM_CORE_ERROR_FAILED,
+ "Current operator name is still unknown");
+ g_object_unref (task);
}
/*****************************************************************************/