GWin32AppInfo: Recognize UWP applications

This commit is contained in:
Руслан Ижбулатов 2020-01-28 03:40:39 +00:00
parent 6931edc28f
commit e1bf1c2711

View File

@ -735,7 +735,8 @@ typedef void (*verb_command_func) (gpointer handler_data1,
static gunichar2 * decide_which_id_to_use (const gunichar2 *program_id, static gunichar2 * decide_which_id_to_use (const gunichar2 *program_id,
GWin32RegistryKey **return_key, GWin32RegistryKey **return_key,
gchar **return_handler_id_u8, gchar **return_handler_id_u8,
gchar **return_handler_id_u8_folded); gchar **return_handler_id_u8_folded,
gunichar2 **return_uwp_aumid);
static GWin32AppInfoURLSchema * get_schema_object (const gunichar2 *schema, static GWin32AppInfoURLSchema * get_schema_object (const gunichar2 *schema,
const gchar *schema_u8, const gchar *schema_u8,
@ -1049,14 +1050,18 @@ get_url_association (const gunichar2 *program_id,
const reg_verb *preferred_verb; const reg_verb *preferred_verb;
gchar *handler_id_u8; gchar *handler_id_u8;
gchar *handler_id_u8_folded; gchar *handler_id_u8_folded;
gunichar2 *uwp_aumid;
GWin32RegistryKey *handler_key; GWin32RegistryKey *handler_key;
if ((handler_id = decide_which_id_to_use (program_id, if ((handler_id = decide_which_id_to_use (program_id,
&handler_key, &handler_key,
&handler_id_u8, &handler_id_u8,
&handler_id_u8_folded)) == NULL) &handler_id_u8_folded,
&uwp_aumid)) == NULL)
return; return;
g_clear_pointer (&uwp_aumid, g_free);
if (!get_verbs (handler_key, &preferred_verb, &verbs, L"", L"Shell")) if (!get_verbs (handler_key, &preferred_verb, &verbs, L"", L"Shell"))
{ {
g_clear_pointer (&handler_id, g_free); g_clear_pointer (&handler_id, g_free);
@ -1121,6 +1126,7 @@ get_file_ext (const gunichar2 *program_id,
GList *verbs; GList *verbs;
gchar *handler_id_u8; gchar *handler_id_u8;
gchar *handler_id_u8_folded; gchar *handler_id_u8_folded;
gunichar2 *uwp_aumid;
GWin32RegistryKey *handler_key; GWin32RegistryKey *handler_key;
GWin32AppInfoFileExtension *file_extn; GWin32AppInfoFileExtension *file_extn;
gchar *file_extension_u8; gchar *file_extension_u8;
@ -1129,9 +1135,12 @@ get_file_ext (const gunichar2 *program_id,
if ((handler_id = decide_which_id_to_use (program_id, if ((handler_id = decide_which_id_to_use (program_id,
&handler_key, &handler_key,
&handler_id_u8, &handler_id_u8,
&handler_id_u8_folded)) == NULL) &handler_id_u8_folded,
&uwp_aumid)) == NULL)
return; return;
g_clear_pointer (&uwp_aumid, g_free);
if (!g_utf16_to_utf8_and_fold (file_extension, if (!g_utf16_to_utf8_and_fold (file_extension,
-1, -1,
&file_extension_u8, &file_extension_u8,
@ -1205,12 +1214,15 @@ static gunichar2 *
decide_which_id_to_use (const gunichar2 *program_id, decide_which_id_to_use (const gunichar2 *program_id,
GWin32RegistryKey **return_key, GWin32RegistryKey **return_key,
gchar **return_handler_id_u8, gchar **return_handler_id_u8,
gchar **return_handler_id_u8_folded) gchar **return_handler_id_u8_folded,
gunichar2 **return_uwp_aumid)
{ {
GWin32RegistryKey *key; GWin32RegistryKey *key;
GWin32RegistryKey *uwp_key;
GWin32RegistryValueType val_type; GWin32RegistryValueType val_type;
gunichar2 *proxy_id; gunichar2 *proxy_id;
gunichar2 *return_id; gunichar2 *return_id;
gunichar2 *uwp_aumid;
gboolean got_value; gboolean got_value;
gchar *handler_id_u8; gchar *handler_id_u8;
gchar *handler_id_u8_folded; gchar *handler_id_u8_folded;
@ -1219,13 +1231,43 @@ decide_which_id_to_use (const gunichar2 *program_id,
if (return_key) if (return_key)
*return_key = NULL; *return_key = NULL;
/* Check the proxy first */ if (return_uwp_aumid)
*return_uwp_aumid = NULL;
key = g_win32_registry_key_get_child_w (classes_root_key, program_id, NULL); key = g_win32_registry_key_get_child_w (classes_root_key, program_id, NULL);
if (key == NULL) if (key == NULL)
return NULL; return NULL;
/* Check for UWP first */
uwp_aumid = NULL;
uwp_key = g_win32_registry_key_get_child_w (key, L"Application", NULL);
if (uwp_key != NULL)
{
got_value = g_win32_registry_key_get_value_w (uwp_key,
NULL,
TRUE,
L"AppUserModelID",
&val_type,
(void **) &uwp_aumid,
NULL,
NULL);
if (got_value && val_type != G_WIN32_REGISTRY_VALUE_STR)
g_clear_pointer (&uwp_aumid, g_free);
if (uwp_aumid == NULL)
g_debug ("ProgramID %S looks like a UWP application, but isn't",
program_id);
g_object_unref (uwp_key);
}
/* Then check for proxy */
proxy_id = NULL; proxy_id = NULL;
if (uwp_aumid == NULL)
{
got_value = g_win32_registry_key_get_value_w (key, got_value = g_win32_registry_key_get_value_w (key,
NULL, NULL,
TRUE, TRUE,
@ -1236,6 +1278,7 @@ decide_which_id_to_use (const gunichar2 *program_id,
NULL); NULL);
if (got_value && val_type != G_WIN32_REGISTRY_VALUE_STR) if (got_value && val_type != G_WIN32_REGISTRY_VALUE_STR)
g_clear_pointer (&proxy_id, g_free); g_clear_pointer (&proxy_id, g_free);
}
return_id = NULL; return_id = NULL;
@ -1277,6 +1320,9 @@ decide_which_id_to_use (const gunichar2 *program_id,
if (return_handler_id_u8_folded) if (return_handler_id_u8_folded)
*return_handler_id_u8_folded = g_steal_pointer (&handler_id_u8_folded); *return_handler_id_u8_folded = g_steal_pointer (&handler_id_u8_folded);
g_clear_pointer (&handler_id_u8_folded, g_free); g_clear_pointer (&handler_id_u8_folded, g_free);
if (return_uwp_aumid)
*return_uwp_aumid = g_steal_pointer (&uwp_aumid);
g_clear_pointer (&uwp_aumid, g_free);
if (return_id == NULL && return_key) if (return_id == NULL && return_key)
*return_key = g_steal_pointer (&key); *return_key = g_steal_pointer (&key);