mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-12 23:46:17 +01:00
gfile: Make g_query_default_handler_async really Async
Despite the name, the call was still doing blocking operations when looking for app handlers via GAppInfo. Now it's possible to use fully async calls. Together with previous commit, the API is now fully async.
This commit is contained in:
parent
8a880e1379
commit
5b04d23fc4
48
gio/gfile.c
48
gio/gfile.c
@ -7603,6 +7603,34 @@ query_default_handler_query_info_cb (GObject *object,
|
|||||||
g_clear_object (&task);
|
g_clear_object (&task);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
on_query_default_handler_for_uri_cb (GObject *object,
|
||||||
|
GAsyncResult *result,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
GTask *task = user_data;
|
||||||
|
GAppInfo *app_info;
|
||||||
|
|
||||||
|
app_info = g_app_info_get_default_for_uri_scheme_finish (result, NULL);
|
||||||
|
|
||||||
|
if (app_info)
|
||||||
|
{
|
||||||
|
g_task_return_pointer (task, g_steal_pointer (&app_info), g_object_unref);
|
||||||
|
g_object_unref (task);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
g_file_query_info_async (g_task_get_source_object (task),
|
||||||
|
G_FILE_ATTRIBUTE_STANDARD_CONTENT_TYPE ","
|
||||||
|
G_FILE_ATTRIBUTE_STANDARD_FAST_CONTENT_TYPE,
|
||||||
|
0,
|
||||||
|
g_task_get_priority (task),
|
||||||
|
g_task_get_cancellable (task),
|
||||||
|
query_default_handler_query_info_cb,
|
||||||
|
task);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* g_file_query_default_handler_async:
|
* g_file_query_default_handler_async:
|
||||||
* @file: a #GFile to open
|
* @file: a #GFile to open
|
||||||
@ -7631,21 +7659,13 @@ g_file_query_default_handler_async (GFile *file,
|
|||||||
uri_scheme = g_file_get_uri_scheme (file);
|
uri_scheme = g_file_get_uri_scheme (file);
|
||||||
if (uri_scheme && uri_scheme[0] != '\0')
|
if (uri_scheme && uri_scheme[0] != '\0')
|
||||||
{
|
{
|
||||||
GAppInfo *appinfo;
|
g_app_info_get_default_for_uri_scheme_async (uri_scheme,
|
||||||
|
cancellable,
|
||||||
/* FIXME: The following still uses blocking calls. */
|
on_query_default_handler_for_uri_cb,
|
||||||
appinfo = g_app_info_get_default_for_uri_scheme (uri_scheme);
|
g_steal_pointer (&task));
|
||||||
g_free (uri_scheme);
|
g_free (uri_scheme);
|
||||||
|
return;
|
||||||
if (appinfo != NULL)
|
|
||||||
{
|
|
||||||
g_task_return_pointer (task, g_steal_pointer (&appinfo), g_object_unref);
|
|
||||||
g_object_unref (task);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
|
||||||
g_free (uri_scheme);
|
|
||||||
|
|
||||||
g_file_query_info_async (file,
|
g_file_query_info_async (file,
|
||||||
G_FILE_ATTRIBUTE_STANDARD_CONTENT_TYPE ","
|
G_FILE_ATTRIBUTE_STANDARD_CONTENT_TYPE ","
|
||||||
@ -7655,6 +7675,8 @@ g_file_query_default_handler_async (GFile *file,
|
|||||||
cancellable,
|
cancellable,
|
||||||
query_default_handler_query_info_cb,
|
query_default_handler_query_info_cb,
|
||||||
g_steal_pointer (&task));
|
g_steal_pointer (&task));
|
||||||
|
|
||||||
|
g_free (uri_scheme);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user