mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-28 06:56:16 +01:00
Merge branch 'wip/pwithnall/2119-osx-app-info' into 'master'
Debuggability improvements in gosxappinfo.m See merge request GNOME/glib!1787
This commit is contained in:
commit
737a853f8d
@ -43,7 +43,7 @@ GLIB_AVAILABLE_IN_2_52
|
|||||||
GType g_osx_app_info_get_type (void) G_GNUC_CONST;
|
GType g_osx_app_info_get_type (void) G_GNUC_CONST;
|
||||||
|
|
||||||
GLIB_AVAILABLE_IN_2_52
|
GLIB_AVAILABLE_IN_2_52
|
||||||
char * g_osx_app_info_get_filename (GOsxAppInfo *info);
|
const char *g_osx_app_info_get_filename (GOsxAppInfo *info);
|
||||||
|
|
||||||
GLIB_AVAILABLE_IN_2_52
|
GLIB_AVAILABLE_IN_2_52
|
||||||
GList * g_osx_app_info_get_all_for_scheme (const gchar *scheme);
|
GList * g_osx_app_info_get_all_for_scheme (const gchar *scheme);
|
||||||
|
@ -168,6 +168,7 @@ get_bundle_string_value (NSBundle *bundle,
|
|||||||
static CFStringRef
|
static CFStringRef
|
||||||
create_cfstring_from_cstr (const gchar *cstr)
|
create_cfstring_from_cstr (const gchar *cstr)
|
||||||
{
|
{
|
||||||
|
g_return_val_if_fail (cstr != NULL, NULL);
|
||||||
return CFStringCreateWithCString (NULL, cstr, kCFStringEncodingUTF8);
|
return CFStringCreateWithCString (NULL, cstr, kCFStringEncodingUTF8);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -226,8 +227,8 @@ url_escape_hostname (const char *url)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static CFURLRef
|
static CFURLRef
|
||||||
create_url_from_cstr (gchar *cstr,
|
create_url_from_cstr (const gchar *cstr,
|
||||||
gboolean is_file)
|
gboolean is_file)
|
||||||
{
|
{
|
||||||
gchar *puny_cstr;
|
gchar *puny_cstr;
|
||||||
CFStringRef str;
|
CFStringRef str;
|
||||||
@ -279,11 +280,17 @@ create_urlspec_for_appinfo (GOsxAppInfo *info,
|
|||||||
GList *uris,
|
GList *uris,
|
||||||
gboolean are_files)
|
gboolean are_files)
|
||||||
{
|
{
|
||||||
LSLaunchURLSpec *urlspec = g_new0 (LSLaunchURLSpec, 1);
|
LSLaunchURLSpec *urlspec = NULL;
|
||||||
gchar *app_cstr = g_osx_app_info_get_filename (info);
|
const gchar *app_cstr;
|
||||||
|
|
||||||
|
g_return_val_if_fail (G_IS_OSX_APP_INFO (info), NULL);
|
||||||
|
|
||||||
|
urlspec = g_new0 (LSLaunchURLSpec, 1);
|
||||||
|
app_cstr = g_osx_app_info_get_filename (info);
|
||||||
|
g_assert (app_cstr != NULL);
|
||||||
|
|
||||||
/* Strip file:// from app url but ensure filesystem url */
|
/* Strip file:// from app url but ensure filesystem url */
|
||||||
urlspec->appURL = create_url_from_cstr (app_cstr + 7, TRUE);
|
urlspec->appURL = create_url_from_cstr (app_cstr + strlen ("file://"), TRUE);
|
||||||
urlspec->launchFlags = kLSLaunchDefaults;
|
urlspec->launchFlags = kLSLaunchDefaults;
|
||||||
urlspec->itemURLs = create_url_list_from_glist (uris, are_files);
|
urlspec->itemURLs = create_url_list_from_glist (uris, are_files);
|
||||||
|
|
||||||
@ -402,7 +409,7 @@ g_osx_app_info_get_executable (GAppInfo *appinfo)
|
|||||||
return info->executable;
|
return info->executable;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *
|
const char *
|
||||||
g_osx_app_info_get_filename (GOsxAppInfo *info)
|
g_osx_app_info_get_filename (GOsxAppInfo *info)
|
||||||
{
|
{
|
||||||
g_return_val_if_fail (info != NULL, NULL);
|
g_return_val_if_fail (info != NULL, NULL);
|
||||||
@ -431,7 +438,8 @@ g_osx_app_info_get_icon (GAppInfo *appinfo)
|
|||||||
|
|
||||||
if (!info->icon)
|
if (!info->icon)
|
||||||
{
|
{
|
||||||
gchar *icon_name, *app_uri, *icon_uri;
|
const gchar *app_uri;
|
||||||
|
gchar *icon_name, *icon_uri;
|
||||||
GFile *file;
|
GFile *file;
|
||||||
|
|
||||||
icon_name = get_bundle_string_value (info->bundle, @"CFBundleIconFile");
|
icon_name = get_bundle_string_value (info->bundle, @"CFBundleIconFile");
|
||||||
@ -439,7 +447,7 @@ g_osx_app_info_get_icon (GAppInfo *appinfo)
|
|||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
app_uri = g_osx_app_info_get_filename (info);
|
app_uri = g_osx_app_info_get_filename (info);
|
||||||
icon_uri = g_strconcat (app_uri + 7, "/Contents/Resources/", icon_name,
|
icon_uri = g_strconcat (app_uri + strlen ("file://"), "/Contents/Resources/", icon_name,
|
||||||
g_str_has_suffix (icon_name, ".icns") ? NULL : ".icns", NULL);
|
g_str_has_suffix (icon_name, ".icns") ? NULL : ".icns", NULL);
|
||||||
g_free (icon_name);
|
g_free (icon_name);
|
||||||
|
|
||||||
@ -459,9 +467,14 @@ g_osx_app_info_launch_internal (GAppInfo *appinfo,
|
|||||||
GError **error)
|
GError **error)
|
||||||
{
|
{
|
||||||
GOsxAppInfo *info = G_OSX_APP_INFO (appinfo);
|
GOsxAppInfo *info = G_OSX_APP_INFO (appinfo);
|
||||||
LSLaunchURLSpec *urlspec = create_urlspec_for_appinfo (info, uris, are_files);
|
LSLaunchURLSpec *urlspec;
|
||||||
gint ret, success = TRUE;
|
gint ret, success = TRUE;
|
||||||
|
|
||||||
|
g_return_val_if_fail (G_IS_OSX_APP_INFO (appinfo), FALSE);
|
||||||
|
g_return_val_if_fail (error == NULL || *error == NULL, FALSE);
|
||||||
|
|
||||||
|
urlspec = create_urlspec_for_appinfo (info, uris, are_files);
|
||||||
|
|
||||||
if ((ret = LSOpenFromURLSpec (urlspec, NULL)))
|
if ((ret = LSOpenFromURLSpec (urlspec, NULL)))
|
||||||
{
|
{
|
||||||
/* TODO: Better error codes */
|
/* TODO: Better error codes */
|
||||||
|
Loading…
Reference in New Issue
Block a user